使用另一个嵌套查询中的值更新SQL表
我目前正在使用SQL Server代理作业为我的内部web应用程序创建主用户表,从其他3个数据库中提取数据;Sharepoint、实践管理系统和我们的人力资源数据库 现在是使用另一个嵌套查询中的值更新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,
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;