使用另一个嵌套查询中的值更新SQL表

时间:2011-01-10 15:39:03

标签: sql sql-server sql-server-2008 merge

我目前正在使用SQL Server代理作业为我的内部Web应用程序创建主用户表,从其他3个数据库中提取数据; Sharepoint,实践管理系统和我们的人力资源数据库。

目前它正在......

truncate table my_tools.dbo.tb_staff
go
insert into my_tools.dbo.tb_staff 
 (username
 ,firstname
 ,surname
 ,chargeoutrate)

    select right(wss.nt_user_name,
  ,hr.firstname
  ,hr.surname
  ,pms.chargeoutrate

    from sqlserver.pms.dbo.staff as pms

    inner join sqlserver.wss_content.dbo.vw_staffwss as wss
 on pms.nt_user_name = wss.nt_user_name

    inner join sqlserver.hrdb.dbo.vw_staffdetails as hr
 on wss.fullname = hr.knownas
go

问题是整个表格作为第一步被清除,因此我在tb_staff上识别的自动增量主键肯定会改变。此外,如果某人从sharepoint或PMS中删除,则不会在此表中重新创建这些内容,这将导致整个数据库中出现不一致。

我希望保留此表中的条目,即使它们已从其他系统中删除。

我想我想做的是: 1)将tb_staff中的所有退出条目标记为非活动状态(使用名为active的列并将其设置为false) 2)对三个连接的表运行查询并更新每个找到的记录,同时将它们标记为活动。

我无法看到如何在Update语句中嵌套select语句,就像我在这里使用Insert语句一样。

我怎样才能做到这一点?

*请注意我已将我的SQL编辑为4列并简化了它,因此很小的错误可能是由于匆忙编辑。真正的查询要大得多。

1 个答案:

答案 0 :(得分:3)

WITH source AS(
SELECT RIGHT(wss.nt_user_name, 10) nt_user_name, /*Or whatever - this is invalid in the original SQL*/
       hr.firstname,
       hr.surname,
       pms.chargeoutrate
FROM   staff AS pms
       INNER JOIN vw_staffwss AS wss
         ON pms.nt_user_name = wss.nt_user_name
       INNER JOIN vw_staffdetails AS hr
         ON wss.fullname = hr.knownas  
)
MERGE 
        INTO tb_staff
        USING source
        ON source.nt_user_name= tb_staff.username /*Or whatever you are using as the key */
          WHEN MATCHED 
            THEN UPDATE SET active=1  /*Can synchronise other columns here if needed*/
        WHEN NOT MATCHED BY TARGET 
            THEN INSERT (username, firstname, surname, chargeoutrate, active) VALUES (nt_user_name,firstname, surname, chargeoutrate, 1)
        WHEN NOT MATCHED BY source 
            THEN UPDATE SET active=0;