我读过这个关于获取插入行的身份的问题。我的问题有点相关。
有没有办法获取插入行的 guid?我正在使用的表有一个 guid 作为主键(默认为 newid),我想在插入行后检索该 guid。
有没有类似的东西@@IDENTITY
,IDENT_CURRENT
或者SCOPE_IDENTITY
对于Guids?
我读过这个关于获取插入行的身份的问题。我的问题有点相关。
有没有办法获取插入行的 guid?我正在使用的表有一个 guid 作为主键(默认为 newid),我想在插入行后检索该 guid。
有没有类似的东西@@IDENTITY
,IDENT_CURRENT
或者SCOPE_IDENTITY
对于Guids?
您可以使用 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() 的新功能。如果您的指南不需要晦涩难懂,那么它是一种可能的选择。
另一种更清洁的方法,如果插入单行
CREATE TABLE MyTable
(
MyPK UNIQUEIDENTIFIER DEFAULT NEWID(),
MyColumn1 NVARCHAR(100),
MyColumn2 NVARCHAR(100)
)
DECLARE @MyID UNIQUEIDENTIFIER;
SET @MyID = NEWID();
INSERT INTO
MyTable
(
MyPK
MyColumn1,
MyColumn2
)
VALUES
(
@MyID,
'MyValue1',
'MyValue2'
)
SELECT @MyID;