Heim >Backend-Entwicklung >C++ >Wie rufe ich die zuletzt eingefügte ID nach einem SQL INSERT in C# MVC 4 ab?
Abrufen der ID eines neu eingefügten SQL-Datensatzes in C# MVC 4
Das Einfügen von Daten in eine SQL Server-Tabelle mit C# MVC 4 erfordert einen Mechanismus, um die ID der neu hinzugefügten Zeile zu erhalten. Während cmd.ExecuteNonQuery()
die Anzahl der betroffenen Zeilen angibt, gibt es nicht die generierte ID zurück.
Methode für SQL Server 2005 und höher:
Der effizienteste Ansatz nutzt die OUTPUT
-Klausel:
<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) OUTPUT INSERTED.ID VALUES(@na,@occ)", con)) { cmd.Parameters.AddWithValue("@na", Mem_NA); cmd.Parameters.AddWithValue("@occ", Mem_Occ); con.Open(); int newId = (int)cmd.ExecuteScalar(); if (con.State == System.Data.ConnectionState.Open) con.Close(); }</code>
Alternative für ältere SQL Server-Versionen:
Für SQL Server-Versionen vor 2005 verwenden Sie 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)) { cmd.Parameters.AddWithValue("@na", Mem_NA); cmd.Parameters.AddWithValue("@occ", Mem_Occ); con.Open(); int newId = Convert.ToInt32(cmd.ExecuteScalar()); if (con.State == System.Data.ConnectionState.Open) con.Close(); }</code>
Diese Codeausschnitte veranschaulichen, wie Sie die neu generierte ID nach einem INSERT-Vorgang abrufen und so die ordnungsgemäße Datenverarbeitung in Ihrer C# MVC 4-Anwendung sicherstellen. Denken Sie daran, Mem_Basic
, Mem_Na
und Mem_Occ
durch Ihre tatsächlichen Tabellen- und Spaltennamen zu ersetzen.
Das obige ist der detaillierte Inhalt vonWie rufe ich die zuletzt eingefügte ID nach einem SQL INSERT in C# MVC 4 ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!