Rumah  >  Artikel  >  pangkalan data  >  Mengapa "ALTER IGNORE TABLE" Masih Menghasilkan Ralat "Integriti Kekangan Pelanggaran" dalam MySQL InnoDB?

Mengapa "ALTER IGNORE TABLE" Masih Menghasilkan Ralat "Integriti Kekangan Pelanggaran" dalam MySQL InnoDB?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-12 01:46:02223semak imbas

Why Does

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:

  1. Tukar jadual ke enjin storan MyISAM menggunakan arahan:

    ALTER TABLE table ENGINE MyISAM;
  2. Jalankan pernyataan ALTER IGNORE TABLE untuk mencipta indeks unik:

    ALTER IGNORE TABLE table ADD UNIQUE INDEX dupidx (field);
  3. 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!

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