Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menyelesaikan Ralat 'BLOB/TEXT yang digunakan dalam spesifikasi utama tanpa panjang kunci' MySQL?

Bagaimana untuk Menyelesaikan Ralat 'BLOB/TEXT yang digunakan dalam spesifikasi utama tanpa panjang kunci' MySQL?

Linda Hamilton
Linda Hamiltonasal
2025-01-19 23:36:10559semak imbas

How to Resolve MySQL's

Menyelesaikan masalah Ralat Spesifikasi Utama BLOB/TEXT MySQL

Mentakrifkan kunci utama atau indeks pada jadual MySQL yang mengandungi lajur BLOB atau TEXT selalunya menghasilkan ralat berikut:

<code>BLOB/TEXT column 'message_id' used in key specification without a key length</code>

Ralat ini timbul kerana indeks MySQL memerlukan jenis data panjang tetap. Lajur BLOB dan TEXT, sebagai panjang berubah-ubah, memerlukan spesifikasi panjang utama untuk penentuan saiz indeks. Walau bagaimanapun, penetapan panjang kunci secara langsung untuk BLOB/TEXT tidak disokong.

Strategi Penyelesaian:

Beberapa pendekatan boleh menangani had ini:

  • Kecualikan BLOB/TEXT daripada Kunci/Indeks: Penyelesaian paling mudah ialah mengalih keluar lajur BLOB atau TEKS daripada kunci utama atau definisi indeks.
  • Gunakan Lajur VARCHAR: Gantikan BLOB/TEXT dengan lajur VARCHAR, nyatakan panjang maksimum. Yang penting, pastikan panjang ini di bawah 256 aksara untuk mengelakkan penukaran automatik kepada SMALLTEXT, yang tidak serasi dengan kekunci.
  • Gunakan Kekunci Komposit: Untuk pengecam unik yang melebihi kapasiti VARCHAR tunggal, buat kunci komposit menggunakan berbilang lajur.

Pertimbangan Lanjut:

Ralat "spesifikasi kunci tanpa panjang kunci" juga boleh nyata walaupun tanpa penglibatan lajur BLOB/TEXT langsung. Ini berlaku apabila panjang kunci VARCHAR melebihi 255 aksara, mencetuskan penukaran tersirat kepada SMALLTEXT.

Untuk mengelakkan perkara ini, pastikan semua lajur VARCHAR yang digunakan dalam kekunci mempunyai panjang maksimum di bawah 255 aksara.

Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan Ralat 'BLOB/TEXT yang digunakan dalam spesifikasi utama tanpa panjang kunci' MySQL?. 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