Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用另一个嵌套查询中的值更新SQL表_Sql_Sql Server_Sql Server 2008_Merge - Fatal编程技术网

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

使用另一个嵌套查询中的值更新SQL表,sql,sql-server,sql-server-2008,merge,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,

我目前正在使用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列,并对其进行了简化,因此小错误可能是由于匆忙编辑造成的。真正的查询要大得多。

除了更新标志外,您还想插入新用户吗?如果是,您使用的是哪个版本的SQL Server?希望是2008,这样您就可以使用
合并
!是的,我想更新现有条目并添加任何新条目。我使用的是SQL Server 2008。在截断表之前,能否将数据放入临时表中,以便在流程完成后解决差异?@Suirtmed我可以这样做,但我不确定以后如何解决差异。我仍然会遇到同样的问题,必须根据另一个查询更新tb_staff表的值。+1@Martin。回答很好,但包含一个合并链接并没有什么坏处。我以前从未听说过这个命令。我害怕我得用光标做点什么。非常感谢!
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;