首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >T-Sql @@Identity

T-Sql @@Identity
EN

Stack Overflow用户
提问于 2010-09-13 20:04:42
回答 5查看 1.7K关注 0票数 6

有人知道在使用T-Sql时如何返回@@Identity吗?

如下所示:

代码语言:javascript
复制
set @Sql = "insert into table....values()..."
exec @sql
return @@Identity
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-09-13 20:14:30

代码语言:javascript
复制
INSERT INTO TableName (Field1, Field2, Field3) VALUES (1, 2, 3);
SELECT SCOPE_IDENTITY();

这是一个多语句批处理,所以我不确定每个客户端库是否都会以相同的方式返回值;例如,在传统的ADO中,您可能需要前进到下一个记录集,然后才能读取值。但是如果您使用ADO.NET,我知道您可以对上面的整个字符串使用ExecuteScalar,它将很好地返回您的SCOPE_IDENTITY值。

注意: ADO.NET将返回值作为decimal,而不是您所期望的int。这是因为无论出于什么原因,SCOPE_IDENTITY的类型都是numeric(38,0)。因此,您需要在将ExecuteScalar结果转换为int之前将其转换为decimal,或者需要将其转换为SELECT CAST(SCOPE_IDENTITY() AS INT) (假设您的标识字段是一个整数,而不是某个更大的数值类型)。

票数 3
EN

Stack Overflow用户

发布于 2010-09-13 20:20:22

看起来您的隐式需求之一是执行动态SQL。虽然我建议不要这样做,但你可以用下面的代码来完成你想要的东西:

代码语言:javascript
复制
set @Sql = 'insert into table....values()...; select SCOPE_IDENTITY()'
exec(@Sql)
票数 7
EN

Stack Overflow用户

发布于 2010-09-13 20:06:20

如下所示:

代码语言:javascript
复制
INSERT INTO Table(...)
OUTPUT INSERTED.IdColumn
VALUES(...)
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3700212

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档