MySQL: Menyelesaikan Ralat "Pelanggaran Kekangan Integriti" semasa ALTER IGNORE TABLE
Apabila menggunakan pernyataan ALTER IGNORE TABLE dalam MySQL untuk mengalih keluar pendua dan buat indeks unik, anda mungkin menghadapi ralat "Pelanggaran kekangan integriti". Ini berlaku walaupun dokumentasi MySQL menunjukkan bahawa kata kunci IGNORE harus menghalang ralat tersebut.
Isu ini nampaknya terletak pada pepijat dalam versi InnoDB MySQL untuk versi tertentu. Sambungan IGNORE mempunyai fungsi terhad dengan InnoDB, menyebabkan ralat kunci pendua berterusan walaupun digunakan.
Untuk menyelesaikan isu ini, pertimbangkan pendekatan alternatif berikut:
Tukar jadual ke enjin storan MyISAM menggunakan arahan:
ALTER TABLE table ENGINE MyISAM;
Jalankan pernyataan ALTER IGNORE TABLE untuk mencipta indeks unik:
ALTER IGNORE TABLE table ADD UNIQUE INDEX dupidx (field);
Tukar semula jadual kembali ke InnoDB menggunakan arahan:
ALTER TABLE table ENGINE InnoDB;
Perhatikan bahawa kaedah ini mungkin tidak berfungsi jika jadual mempunyai kekangan kunci asing. Dalam kes sedemikian, anda perlu mengalih keluar kekangan ini buat sementara waktu dan kemudian menambahkannya semula selepas melengkapkan penciptaan indeks.
Atas ialah kandungan terperinci Mengapa 'ALTER IGNORE TABLE' Masih Menghasilkan Ralat 'Integriti Kekangan Pelanggaran' dalam MySQL InnoDB?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!