Ralat Integriti Pangkalan Data: Panduan Penyelesaian Masalah untuk "Tidak dapat mendayakan kekangan"
Menghadapi ralat "Tidak dapat mendayakan kekangan. Satu atau lebih baris mengandungi nilai yang melanggar kekangan kunci bukan nol, unik atau asing" biasanya menunjukkan isu integriti pangkalan data. Panduan ini akan membantu anda mengenal pasti dan menyelesaikan isu ini.
Analisis Punca Masalah
Ralat ini menunjukkan bahawa semasa melakukan gabungan luar, beberapa baris dalam set hasil melanggar satu atau lebih kekangan pangkalan data. Kekangan ini termasuk:
Penyelesaian
1. Semak nilai nol:
Jika atribut AllowDBNull
ditetapkan kepada false
, mana-mana lajur kosong akan mencetuskan ralat ini. Semak set hasil yang dikembalikan untuk memastikan semua lajur yang diperlukan mengandungi data atau gunakan ruang letak kosong (cth., NULL
, "").
2. Padamkan baris pendua:
Semak syarat cantum untuk memastikan ia menghalang baris pendua daripada dibuat. Baris pendua mungkin disebabkan oleh ralat gabungan atau keadaan penapis yang tiada.
3. Semak jenis data:
Sahkan bahawa jenis data lajur set hasil sepadan dengan jenis data yang ditakrifkan dalam skema pangkalan data. Ketidakpadanan jenis data boleh membawa kepada perwakilan nilai yang tidak konsisten.
4. Gunakan sambung luar yang betul:
Sambungan luar menggunakan jadual luaran (di sini cc1assiscrseval
) boleh memperkenalkan nilai nol. Pastikan anda menandai jadual luaran secara eksplisit menggunakan OUTER()
seperti yang ditunjukkan dalam pertanyaan SQL yang disediakan.
5. Semak butiran ralat:
Adalah disyorkan untuk menggunakan kaedah GetErrors()
untuk mendapatkan maklumat terperinci tentang baris dan lajur yang menyinggung perasaan. Ini akan menentukan pelanggaran dan membantu anda mengasingkan punca ralat.
Cadangan lain
Atas ialah kandungan terperinci Gagal Mendayakan Kekangan: Bagaimana Saya Boleh Menyelesaikan Masalah Integriti Data dalam Pangkalan Data Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!