Kunci Komposit sebagai Kunci Asing dalam SQL
Dalam senario yang diberikan, anda mempunyai jadual tutorial dengan kunci utama komposit yang terdiri daripada (beggingTime , hari, tutorId) dan jadual kumpulan dengan kunci utama groupId. Anda berhasrat untuk mewujudkan hubungan antara jadual ini dengan mencipta kunci asing dalam kumpulan yang merujuk kunci komposit dalam tutorial.
Untuk mencapai ini, anda boleh menambah kekangan kunci asing berikut pada jadual kumpulan anda:
FOREIGN KEY (`beggingTime`, `day`, `tutorId`) REFERENCES tutorial(`beggingTime`, `day`, `tutorId`)
Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa menggunakan kunci utama komposit sebagai kunci asing boleh memberi kesan kepada prestasi. SQL dioptimumkan untuk mengendalikan perhubungan berdasarkan kunci primer integer atau kunci pengganti. Menggunakan kekunci komposit boleh memperkenalkan kerumitan tambahan dan mengurangkan kecekapan pertanyaan.
Untuk mengurangkan isu ini, pertimbangkan untuk menstruktur semula jadual tutorial anda untuk memasukkan kunci utama pengganti, seperti lajur integer kenaikan automatik. Ini akan membolehkan perhubungan yang lebih cekap antara kedua-dua jadual sambil mengekalkan keunikan kunci komposit anda. Kunci komposit kemudiannya boleh dikekalkan sebagai indeks unik untuk carian pantas apabila perlu.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Kunci Komposit dengan Cekap sebagai Kunci Asing dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!