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

如何在 SQL Server 中插入数据库后检索最后插入的 ID?

DDD
发布: 2025-01-21 23:12:13
原创
339 人浏览过

How to Retrieve the Last Inserted ID After a Database Insertion in SQL Server?

获取SQL Server数据库插入后最新的ID

在数据库插入数据后,经常需要获取最新插入记录的ID。让我们来看一个场景:需要在aspnet_GameProfiles表中插入一行后,获取自动递增的GamesProfileId。

以下代码片段执行INSERT语句,但没有捕获新生成的GamesProfileId的机制。为实现此目的,我们将探讨基于所用SQL Server版本的不同方法。

SQL Server 2005及以上版本(无插入触发器)

对于SQL Server 2005及以上版本,如果aspnet_GameProfiles表上没有定义插入触发器,您可以修改插入语句以包含OUTPUT子句:

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

这将自动返回插入的ID作为查询的输出。您可以使用以下代码检索它:

<code class="language-csharp">SqlCommand myCommand = new SqlCommand(insertSql, myConnection);
...
SqlDataReader reader = myCommand.ExecuteReader();
reader.Read();
Int32 newId = reader.GetInt32(0);</code>
登录后复制

SQL Server 2000或插入触发器

如果您使用的是SQL Server 2000或表上有插入触发器,您可以使用SCOPE_IDENTITY()函数:

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

执行查询后,您可以使用以下代码检索最新插入的ID:

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

通过使用这些技术,您可以有效地获取最后插入的GamesProfileId,从而能够在应用程序中将其用于后续插入或其他操作。

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

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