Heim >Backend-Entwicklung >C++ >Wie rufe ich die zuletzt eingefügte ID nach einem SQL INSERT in C# MVC 4 ab?

Wie rufe ich die zuletzt eingefügte ID nach einem SQL INSERT in C# MVC 4 ab?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-17 21:51:10737Durchsuche

How to Retrieve the Last Inserted ID After an SQL INSERT in C# MVC 4?

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn