Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mendapatkan ID Auto-Generasi Selepas Memasukkan Pukal dalam MySQL?

Bagaimana untuk Mendapatkan ID Auto-Generasi Selepas Memasukkan Pukal dalam MySQL?

DDD
DDDasal
2024-12-28 09:34:09676semak imbas

How to Retrieve Auto-Generated IDs After Bulk Insertion in MySQL?

Sisipan Pukal dengan Pengambilan ID dalam MySQL

Memasukkan berbilang baris ke dalam jadual MySQL dan mendapatkan ID baharu adalah keperluan biasa yang mungkin tidak segera jelas untuk dilaksanakan. Dokumen ini menerangkan cara untuk mencapai ini menggunakan fungsi LAST_INSERT_ID() dan ROW_COUNT() MySQL, terutamanya apabila menggunakan enjin storan InnoDB.

Penjanaan ID Berjujukan InnoDB

Apabila menggunakan enjin storan InnoDB dengan MySQL, sisipan pukal mengekalkan penetapan berurutan AUTO INCREMENT ID, memandangkan innodb_autoinc_lock_mode ditetapkan kepada 0 (tradisional) atau 1 (berturut-turut).

Mendapatkan Susunan ID

Untuk mendapatkan tatasusunan ID selepas sisipan pukal, ikut ini langkah:

  1. Laksanakan pertanyaan sisipan pukal.
  2. Dapatkan ID pertama menggunakan LAST_INSERT_ID().
  3. Kira ID terakhir dengan menambahkan ROW_COUNT()-1 pada ID pertama.
  4. Jana tatasusunan ID daripada ID pertama hingga terakhir secara berperingkat.

Contoh:

-- Insert bulk rows
INSERT INTO table_name (column1, column2) VALUES (val1, val2), (val3, val4), (val5, val6);

-- Get the first ID
SET @first_id = LAST_INSERT_ID();

-- Get the number of rows inserted
SET @num_rows = ROW_COUNT();

-- Create an array of IDs
SET @ids = ARRAY();

-- Populate the array
WHILE (@i < @num_rows) DO
  SET @ids[@i] = @first_id + @i;
  SET @i = @i + 1;
END WHILE;

Teknik ini dengan cekap menyediakan pelbagai ID yang baru dijana selepas sisipan pukal, membolehkan pemprosesan atau penggunaan selanjutnya dalam logik aplikasi.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan ID Auto-Generasi Selepas Memasukkan Pukal dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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