Kunci Utama MySQL sebagai Kunci Asing: Ralat dan Penyelesaian
Apabila mentakrifkan kekangan kunci asing dalam MySQL, adalah penting untuk memastikan jadual rujukan dan jadual yang dirujuk mempunyai indeks yang sesuai. Keperluan ini boleh menyebabkan isu apabila menggunakan kunci utama satu jadual sebagai kunci asing dalam jadual lain.
Kunci Utama sebagai Kunci Asing
Soalan pertama yang anda kemukakan ialah jika mungkin untuk mencipta kunci utama yang juga merupakan kunci asing. Jawapannya ya, mungkin, tetapi ada hadnya.
Kod Ralat 1005
Ralat yang anda hadapi, kod ralat 1005, menunjukkan bahawa MySQL tidak boleh mencipta asing kekangan utama kerana jadual yang dirujuk, dbimmobili.Immobile, tidak mempunyai indeks pada lajur yang dirujuk dalam kunci asing kekangan.
Penyelesaian
Untuk menyelesaikan isu ini, anda perlu mencipta indeks pada lajur ComuneImmobile, ViaImmobile, CivicoImmobile dan InternoImmobile dalam jadual dbimmobili.Immobile. Indeks ini akan memastikan MySQL boleh mencari rekod yang dirujuk dengan cekap semasa melakukan semakan kunci asing.
Setelah anda mencipta indeks, anda sepatutnya boleh mengeksport perubahan tanpa menghadapi ralat.
Nota Tambahan
Adalah penting untuk ambil perhatian bahawa anda juga mungkin menghadapi isu jika jenis data lajur yang digunakan dalam kekangan kunci asing berbeza antara jadual rujukan dan rujukan. Pastikan jenis data serasi untuk mengelakkan sebarang kemungkinan ralat.
Atas ialah kandungan terperinci Ralat Kunci Asing MySQL 1005: Bagaimana Menyelesaikan Konflik Kunci Asing Utama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!