我已经阅读了
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不需要默默无闻,那么它可能是另一种选择.