加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 16:21:50 所属栏目:MsSql教程 来源:网络整理
导读:我已经阅读了 this question关于获取插入行的标识.我的问题有点相关. 有没有办法获得插入行的guid?我正在使用的表有一个guid作为主键(默认为newid),我想在插入行后检索该guid. Guids有@@ IDENTITY,IDENT_CURRENT或SCOPE_IDENTITY吗? 解决方法 您可以使用OUT
我已经阅读了 this question关于获取插入行的标识.我的问题有点相关.

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

Guids有@@ IDENTITY,IDENT_CURRENT或SCOPE_IDENTITY吗?

解决方法

您可以使用OUTPUT功能将默认值返回到参数中.
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()的新功能.如果你的Guids不需要默默无闻,那么它可能是另一种选择.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读