Rumah > pangkalan data > tutorial mysql > 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
Lepaskan: 2024-11-12 01:46:02
asal
285 orang telah melayarinya

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;
    Salin selepas log masuk
  2. Jalankan pernyataan ALTER IGNORE TABLE untuk mencipta indeks unik:

    ALTER IGNORE TABLE table ADD UNIQUE INDEX dupidx (field);
    Salin selepas log masuk
  3. Tukar semula jadual kembali ke InnoDB menggunakan arahan:

    ALTER TABLE table ENGINE InnoDB;
    Salin selepas log masuk

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!

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