首頁 > 資料庫 > mysql教程 > 如何使用 C# MVC 4 檢索 SQL Server 中新插入記錄的 ID?

如何使用 C# MVC 4 檢索 SQL Server 中新插入記錄的 ID?

Linda Hamilton
發布: 2025-01-17 01:46:08
原創
938 人瀏覽過

How to Retrieve the ID of a Newly Inserted Record in SQL Server using C# MVC 4?

使用 C# MVC 4 擷取新插入的 SQL Server 記錄的 ID

問題:

如何在 MVC 4 應用程式中使用 C# 向 SQL Server 表插入數據,然後取得新新增記錄的 ID?

解:

有兩種主要方法,取決於您的 SQL Server 版本:

SQL Server 2005 及更高版本:

SQL Server 2005 及後續版本最有效的方法是利用 OUTPUT 子句:

<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na, Mem_Occ) OUTPUT INSERTED.ID VALUES (@na, @occ)", con))
{
    // ... parameter assignments for @na and @occ ...
    int newId = (int)cmd.ExecuteScalar();
    return newId;
}</code>
登入後複製

這條 SQL 語句插入資料並立即傳回新產生的 ID。

舊版 SQL Server 版本(2005 年以前):

對於較舊的 SQL Server 版本,您需要一個由兩部分組成的查詢:一個 INSERT 語句,後面跟著 SCOPE_IDENTITY():

<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na, Mem_Occ) VALUES (@na, @occ); SELECT SCOPE_IDENTITY();", con))
{
    // ... parameter assignments for @na and @occ ...
    int newId = Convert.ToInt32(cmd.ExecuteScalar());
    return newId;
}</code>
登入後複製

此方法首先插入數據,然後使用 SCOPE_IDENTITY() 檢索當前會話和範圍內最後插入的行的 ID。 請注意,SCOPE_IDENTITY() 僅適用於當前會話和範圍,因此如果同時發生多個插入,您可能會得到意想不到的結果。

請記得將 Mem_BasicMem_NaMem_Occ 替換為您實際的表格和欄位名稱。 此外,確保正確的參數化以防止 SQL 注入漏洞。 // ... 部分指示應使用 cmd.Parameters.AddWithValue(...).

新增參數分配代碼的位置

以上是如何使用 C# MVC 4 檢索 SQL Server 中新插入記錄的 ID?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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