Dalam usaha untuk menghalang rekod pendua, pendekatan biasa ialah mencipta indeks unik pada lajur jadual yang berkaitan. Walau bagaimanapun, kesilapan baru-baru ini mengakibatkan penciptaan indeks biasa sebaliknya, membenarkan pendua kekal dalam jadual rekod 20 juta besar.
Soalan: Akan mengubah suai indeks sedia ada kepada unik atau menambah indeks unik baharu untuk lajur tersebut mengalih keluar rekod pendua atau adakah operasi akan gagal disebabkan oleh entri unik sedia ada?
Jawapan:
Menambah indeks unik dengan IGNORE pengubah suai akan mengalih keluar rekod pendua:
<code class="sql">ALTER IGNORE TABLE mytable ADD UNIQUE INDEX myindex (A, B, C, D);</code>
Walau bagaimanapun, pengubah suai ini ditamatkan penggunaannya dalam MySQL 5.7.4 dan kemudian, mengakibatkan ralat. Untuk mengelakkan isu ini, langkah berikut boleh diambil:
Buat jadual sementara untuk menyimpan data daripada jadual asal:
<code class="sql">CREATE TABLE tmp_data SELECT * FROM mytable;</code>
Potong jadual asal:
<code class="sql">TRUNCATE TABLE mytable;</code>
Buat indeks unik pada jadual asal:
<code class="sql">ALTER TABLE mytable ADD UNIQUE INDEX myindex (A, B, C, D);</code>
Salin semula data ke dalam jadual asal sambil mengabaikan baris pendua:
<code class="sql">INSERT IGNORE INTO mytable SELECT * from tmp_data;</code>
Lepaskan jadual sementara:
<code class="sql">DROP TABLE tmp_data;</code>
Sebagai alternatif, tambahkan indeks unik tanpa pengubah suai IGNORE akan menyebabkan pertanyaan gagal dengan Ralat 1062 (kunci pendua).
Atas ialah kandungan terperinci **Bolehkah Anda Mengalih Keluar Rekod Pendua dengan Mengubah Suai Indeks Sedia Ada kepada Unik atau Menambah Rekod Baharu?**. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!