Memenggal Jadual Terkandas Kunci Asing
Apabila jadual mempunyai kekangan kunci asing, cuba memotongnya menggunakan arahan TRUNCATE mungkin mengakibatkan ralat seperti "Tidak boleh memotong jadual yang dirujuk dalam kekangan kunci asing." Ralat ini berlaku kerana TRUNCATE memerlukan kekangan kunci asing dikuatkuasakan.
Melumpuhkan Pemeriksaan Kunci Asing
Untuk memotong jadual kekangan kunci asing, anda perlu melumpuhkan buat sementara waktu semakan kunci asing. Ini boleh dilakukan menggunakan pernyataan berikut:
SET FOREIGN_KEY_CHECKS = 0;
Pernyataan ini melumpuhkan semakan kunci asing, membenarkan perintah TRUNCATE untuk dilaksanakan dengan jayanya. Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa ini juga membenarkan data untuk dimasukkan ke dalam jadual yang mungkin melanggar kekangan kunci asing.
Memotong Jadual
Setelah kunci asing semakan telah dilumpuhkan, arahan TRUNCATE boleh dilaksanakan untuk setiap satu jadual:
TRUNCATE table1; TRUNCATE table2;
Ini akan mengalih keluar semua baris daripada kedua-dua jadual, tanpa mengira perhubungan kunci asing.
Mendayakan Semula Pemeriksaan Kunci Asing
Selepas proses pemangkasan selesai, semakan kunci asing mesti didayakan semula menggunakan perkara berikut kenyataan:
SET FOREIGN_KEY_CHECKS = 1;
Ini akan memulihkan penguatkuasaan kunci asing, memastikan integriti data dikekalkan dalam pangkalan data.
Awas:
Ia adalah penting untuk berhati-hati apabila melumpuhkan semakan kunci asing, kerana ia boleh menyebabkan ketidakkonsistenan data dan rasuah data. Adalah disyorkan untuk hanya melumpuhkan semakan kunci asing apabila perlu dan mendayakannya semula sebaik sahaja operasi yang diperlukan selesai.
Atas ialah kandungan terperinci Bagaimana untuk Memotong Jadual Terkandas Kunci Asing dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!