首頁 > 資料庫 > mysql教程 > 如何在 C# 中的 SQL INSERT 指令後檢索插入的 ID?

如何在 C# 中的 SQL INSERT 指令後檢索插入的 ID?

Linda Hamilton
發布: 2025-01-17 01:36:09
原創
660 人瀏覽過

How to Retrieve the Inserted ID After an SQL INSERT Command in C#?

在 C# 中 SQL INSERT 後擷取自動產生的 ID

透過C#向SQL Server表新增資料時,取得新條目自動產生的ID是常見的需求。 本教學課程示範了兩種方法:使用 OUTPUT 子句(SQL Server 2005 及更高版本)和 SCOPE_IDENTITY() 函數(舊版)。

方法 1:OUTPUT 子句(SQL Server 2005 及更高版本)

OUTPUT子句提供了一個直接的方法來指定包含ID的欄位:

<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) OUTPUT INSERTED.ID VALUES(@na,@occ)", con))</code>
登入後複製

這裡,INSERTED.ID子句中的OUTPUT傳回新插入行的ID。

方法 2:SCOPE_IDENTITY() 函數(較舊的 SQL Server 版本)

對於較舊的 SQL Server 版本,SCOPE_IDENTITY() 檢索目前範圍內最近插入的行的 ID:

<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) VALUES(@na,@occ); SELECT SCOPE_IDENTITY();", con))</code>
登入後複製

此查詢插入數據,然後在單獨的 SCOPE_IDENTITY() 語句中使用 SELECT 來取得 ID。

取得 ID

在這兩種方法中,都使用 ExecuteScalar() 和型別轉換來存取產生的 ID:

<code class="language-csharp">int newId = (int)cmd.ExecuteScalar();</code>
登入後複製

此技術可確保有效檢索新插入的記錄 ID,提供跨不同 SQL Server 版本的相容性。

以上是如何在 C# 中的 SQL INSERT 指令後檢索插入的 ID?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板