gpt4 book ai didi

sql-server - 获取插入行的 PK Guid 的最佳方法

转载 作者:行者123 更新时间:2023-12-02 10:09:37 26 4
gpt4 key购买 nike

我已阅读 this question关于获取插入行的标识。我的问题有点相关。

有没有办法获取插入行的 guid?我正在使用的表有一个 guid 作为主键(默认为 newid),我想在插入行后检索该 guid。

是否有类似 @@IDENTITYIDENT_CURRENTSCOPE_IDENTITY 的 Guid?

最佳答案

您可以使用输出功能将默认值返回到参数中。

CREATE TABLE MyTable
(
MyPK UNIQUEIDENTIFIER DEFAULT NEWID(),
MyColumn1 NVARCHAR(100),
MyColumn2 NVARCHAR(100)
)

DECLARE @myNewPKTable TABLE (myNewPK UNIQUEIDENTIFIER)

INSERT INTO
MyTable
(
MyColumn1,
MyColumn2
)
OUTPUT INSERTED.MyPK INTO @myNewPKTable
VALUES
(
'MyValue1',
'MyValue2'
)

SELECT * FROM @myNewPKTable

但我不得不说,使用唯一标识符作为主键时要小心。对 GUID 进行索引的性能极差,因为任何新生成的 guid 都必须插入到索引的中间,而很少只是添加到末尾。 SQL2005 中有 NewSequentialId() 的新功能。如果您的指南不需要模糊,那么它是一个可能的替代方案。

关于sql-server - 获取插入行的 PK Guid 的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/810829/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com