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
Freigeben: 2025-01-17 21:51:10
Original
755 Leute haben es durchsucht

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:

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();
}
Nach dem Login kopieren

Alternative für ältere SQL Server-Versionen:

Für SQL Server-Versionen vor 2005 verwenden Sie SCOPE_IDENTITY():

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();
}
Nach dem Login kopieren

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!

Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage