Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menyusun Semula dan Menetapkan Semula Kekunci Utama Auto-Increment dalam MySQL untuk Menghapuskan Jurang?
Menyusun Semula Kekunci Utama Penambahan Auto: Penyelesaian untuk Jurang Dalaman
Apabila berurusan dengan kunci utama kenaikan automatik dalam MySQL, adalah perkara biasa untuk menghadapi jurang dalam urutan ID kerana baris yang dipadamkan. Untuk memastikan kesinambungan dan mengekalkan integriti data, menyusun semula kunci utama adalah penting. Artikel ini menyediakan penyelesaian yang komprehensif untuk menangani isu ini.
Seperti yang dinyatakan dalam pertanyaan, baris 15-18 telah dipadamkan, meninggalkan jurang dalam lajur ID. Untuk menetapkan semula dan menetapkan semula nilai kunci utama, ikut langkah berikut:
SET @count = 0; UPDATE `users` SET `users`.`id` = @count:= @count + 1;
Pertanyaan ini menetapkan pembolehubah sementara, @count, kepada sifar dan menambahnya untuk setiap baris dalam jadual pengguna. Lajur id kemudiannya dikemas kini dengan nilai berjujukan baharu.
Jika lajur id digunakan sebagai kunci asing dalam jadual lain, pastikan perhubungan kunci asing telah didayakan ON UPDATE CASCADE dan bukannya ON UPDATE NO ACTION. Ini memastikan bahawa rujukan kepada lajur id dalam jadual lain dikemas kini secara automatik.
Untuk menetapkan semula kiraan kenaikan automatik, laksanakan pernyataan berikut:
ALTER TABLE `users` AUTO_INCREMENT = 1;
Ini akan menetapkan semula kenaikan automatik nilai kepada 1. Walau bagaimanapun, untuk MySQL, ia akan menetapkan semula nilai kepada nilai id maksimum tambah 1.
Dengan melaksanakan langkah ini, anda boleh menyusun semula dan menetapkan semula kunci utama autokenaikan, memastikan kesinambungan dan menghapuskan percanggahan data yang disebabkan oleh baris yang dipadamkan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyusun Semula dan Menetapkan Semula Kekunci Utama Auto-Increment dalam MySQL untuk Menghapuskan Jurang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!