Rumah > pangkalan data > tutorial mysql > Mengapa Indeks SQL saya Gagal Kerana Had Panjang Lajur Utama?

Mengapa Indeks SQL saya Gagal Kerana Had Panjang Lajur Utama?

Susan Sarandon
Lepaskan: 2024-12-22 05:32:14
asal
1083 orang telah melayarinya

Why is my SQL Index Failing Due to Key Column Length Limitations?

Penghadan Panjang Indeks Lajur Utama dalam SQL

Mesej ralat "Lajur 'kunci' dalam jadual 'misc_info' adalah daripada jenis yang tidak sah untuk digunakan sebagai lajur kunci dalam indeks" menunjukkan bahawa panjang lajur kunci melebihi maksimum yang dibenarkan untuk indeks.

Panjang maksimum lajur indeks bergantung pada jenis data yang digunakan. Untuk jenis data nvarchar, panjang maksimum ialah 450 aksara. Ini kerana kekangan unik pada lajur nvarchar tidak boleh melebihi 8000 bait setiap baris dan hanya 900 bait pertama digunakan.

Untuk menyelesaikan isu ini, kurangkan panjang lajur kunci kepada maksimum 450 watak. Pernyataan SQL yang diubah suai berikut mencipta jadual dengan lajur utama nvarchar(450):

create table [misc_info]
(
    [id] INTEGER PRIMARY KEY IDENTITY NOT NULL,
    [key] nvarchar(450) UNIQUE NOT NULL,
    [value] nvarchar(max) NOT NULL
);
Salin selepas log masuk

Jika boleh, pertimbangkan untuk menukar kepada varchar dan bukannya nvarchar, yang boleh meningkatkan panjang maksimum kepada 900 aksara.

Atas ialah kandungan terperinci Mengapa Indeks SQL saya Gagal Kerana Had Panjang Lajur Utama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan