首页 > 数据库 > mysql教程 > 如何在 INSERT 语句后检索 SQL Server 中最后插入的 ID?

如何在 INSERT 语句后检索 SQL Server 中最后插入的 ID?

DDD
发布: 2025-01-21 23:02:11
原创
238 人浏览过

How to Retrieve the Last Inserted ID in SQL Server After an INSERT Statement?

在 SQL Server 中访问新创建的记录的 ID

本指南演示如何获取 SQL Server 中 aspnet_GameProfiles 表中最近插入的记录的 ID。 最佳方法取决于您的 SQL Server 版本:

SQL Server 2005 及更高版本(没有 INSERT 触发器):

对于较新的 SQL Server 版本,最有效的方法是直接在 OUTPUT 语句中利用 INSERT 子句:

<code class="language-sql">INSERT INTO aspnet_GameProfiles (UserId, GameId)
OUTPUT INSERTED.ID
VALUES (@UserId, @GameId);</code>
登录后复制

随后,使用 ExecuteScalar():

检索生成的 ID
<code class="language-csharp">Int32 newId = (Int32)myCommand.ExecuteScalar();</code>
登录后复制
登录后复制

此方法避免了额外的查询,提高了性能。

SQL Server 2000 或使用 INSERT 触发器时:

对于较旧的 SQL Server 版本或涉及 INSERT 触发器的场景,请使用 SCOPE_IDENTITY() 函数:

<code class="language-sql">INSERT INTO aspnet_GameProfiles (UserId, GameId)
VALUES (@UserId, @GameId);
SELECT SCOPE_IDENTITY();</code>
登录后复制

然后可以使用 ExecuteScalar() 访问检索到的 ID:

<code class="language-csharp">Int32 newId = (Int32)myCommand.ExecuteScalar();</code>
登录后复制
登录后复制

通过使用这两种方法中的任何一种,您都可以从 aspnet_GameProfiles 无缝检索新生成的 ID,从而启用需要此信息的后续操作。

以上是如何在 INSERT 语句后检索 SQL Server 中最后插入的 ID?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板