Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan ID yang Dimasukkan Selepas Perintah INSERT dalam Pelayan SQL?

Bagaimana untuk Mendapatkan ID yang Dimasukkan Selepas Perintah INSERT dalam Pelayan SQL?

Mary-Kate Olsen
Lepaskan: 2025-01-17 01:27:08
asal
461 orang telah melayarinya

How to Get the Inserted ID After an INSERT Command in SQL Server?

Mendapatkan semula ID yang Baru Dimasukkan dalam SQL Server daripada C#

Artikel ini menunjukkan cara untuk memasukkan data ke dalam jadual SQL Server menggunakan C# dalam aplikasi MVC 4 dan seterusnya mendapatkan ID rekod yang baru ditambah. Kami akan meneroka kaedah untuk SQL Server 2005 dan lebih baru, dan untuk versi sebelum 2005.

Kaedah 1: SQL Server 2005 dan Kemudian (Menggunakan OUTPUT INSERTED.ID)

Pendekatan ini memanfaatkan klausa OUTPUT, kaedah yang sangat cekap untuk mendapatkan ID yang disisipkan terus dalam pernyataan sisipan itu sendiri.

<code class="language-csharp">public class MemberBasicData
{
    public int Id { get; set; }
    public string Mem_NA { get; set; }
    public string Mem_Occ { get; set; }     
}

public int CreateNewMember(string Mem_NA, string Mem_Occ)
{
    using (SqlConnection con = new SqlConnection(Config.ConnectionString))
    {
        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();
            con.Close();
            return newId;
        }
    }
}</code>
Salin selepas log masuk

Kaedah 2: Versi Pelayan SQL Sebelum 2005 (Menggunakan SCOPE_IDENTITY())

Untuk versi SQL Server yang lebih lama, fungsi SCOPE_IDENTITY() digunakan untuk mendapatkan semula nilai identiti terakhir yang dijana dalam skop semasa.

<code class="language-csharp">public int CreateNewMember(string Mem_NA, string Mem_Occ)
{
    using (SqlConnection con = new SqlConnection(Config.ConnectionString))
    {
        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());
            con.Close();
            return newId;
        }
    }
}</code>
Salin selepas log masuk

Kedua-dua kaedah mencapai hasil yang sama: mengembalikan ID rekod yang baru dimasukkan. Pilihan bergantung pada versi SQL Server anda. Klausa OUTPUT biasanya diutamakan kerana kecekapan dan kejelasannya dalam versi yang lebih baharu. Ingat untuk menggantikan "Config.ConnectionString" dengan rentetan sambungan sebenar anda.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan ID yang Dimasukkan Selepas Perintah INSERT dalam Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan