大佬教程收集整理的这篇文章主要介绍了如何使用SQL Server的OUTPUT子句进行更新,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
尝试类似这样的事情,您仍然必须使用temp表,但它的可读性还不错,并且可以完成工作。
create table #tmp
(
tmpID int idENTITY(1,1) PRIMary KEY CLUSTERED,
xmlData VARCHAR(255),
EntityID INT
)
DECLARE @t2 table
(
tmpID INT,
EntityID INT
)
MERGE dbo.Entitymaster AS EM
USING
(
SELECT tmpID,
xmlData,
EntityID
FROM #tmp
) AS X
ON Em.EntityID = X.EntityID
WHEN NOT MATCHED THEN
INSERT (EntityTypE)
VALUES (X.xmlData)
OUTPUT X.tmpID, INSERTEd.entityID
INTO @t2 (tmpID, EntityID);
updatE T
SET EntityID = T2.EntityID
FROM @t2 T2
INNER JOIN #tmp T
ON T2.tmpID = T.tmpID
@H_262_6@
DECLARE @t2 AS TABLE(id int)
INSERT INTO dbo.Entitymaster
(EntityTypE)
OUTPUT INSERTEd.entityId INTO @t2
SELECT 'G' FROM #tmp
@H_262_6@
#tmp@H_262_6@是一个临时表,其中包含从xml加载的数据。我需要为中
EntityId@H_262_6@包含的每个记录生成一个
#tmp@H_262_6@。可以通过先将记录插入
Entitymaster@H_262_6@表中,然后再
#tmp@H_262_6@为每个记录插入该实体id来完成。
无需将记录插入@t2@H_262_6@,我需要
#tmp@H_262_6@为每个记录进行更新。
有没有可能
以上是大佬教程为你收集整理的如何使用SQL Server的OUTPUT子句进行更新全部内容,希望文章能够帮你解决如何使用SQL Server的OUTPUT子句进行更新所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。