程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了如何使用SQL Server的OUTPUT子句进行更新大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决如何使用sqL Server的OUTPUT子句进行更新?

开发过程中遇到如何使用sqL Server的OUTPUT子句进行更新的问题如何解决?下面主要结合日常开发的经验,给出你关于如何使用sqL Server的OUTPUT子句进行更新的解决方法建议,希望对你解决如何使用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,请注明来意。