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