微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 返回最后插入的ID,而不使用第二个查询

我正在使用sql Server 2008的ASP.NET项目(C#).

当我在数据库中的表中插入一行时,我想获取最后插入的ID,这是表的IDENTITY(自动递增).

我不想使用其他查询,并且做一些像…

SELECT MAX(ID) FROM USERS;

因为 – 即使只有一个查询 – 它感觉很跛脚…

当我插入某些东西时,我通常使用ExecuteNonQuery(),它返回受影响的行数.

int y = Command.ExecuteNonQuery();

没有方法返回最后插入的ID而不使用另一个查询

解决方法

大多数人通过以下方式做到这一点:
INSERT dbo.Users(Username)
VALUES('my new name');

SELECT NewID = ScopE_IDENTITY();

(或者,而不是一个查询,将其分配给一个变量.)

所以它不是真的两个查询表

但是还有以下几种方法

INSERT dbo.Users(Username)
OUTPUT inserted.ID
VALUES('my new name');

尽管如此,您将无法使用ExecuteNonQuery来检索.

原文地址:https://www.jb51.cc/csharp/94605.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐