Strategi Pertanyaan Cekap untuk Kekunci Berbilang Lajur dalam MySQL
Apabila berurusan dengan jadual tiga lajur dan keperluan untuk mengemas kini atau memasukkan berdasarkan pada gabungan unik dua lajur, persoalan timbul: bagaimana untuk mencapai prestasi optimum? Pendekatan tradisional menggunakan KEMASKINI PADA DUPLICATE KEY menghadapi cabaran apabila tiada lajur unik wujud.
Mujurlah, MySQL menawarkan penyelesaian dengan membenarkan penciptaan kunci komposit, menggabungkan berbilang lajur untuk membentuk pengecam unik.
Melaksanakan Kekunci Komposit
Untuk mewujudkan kunci komposit, anda boleh menggunakan sintaks berikut:
CREATE INDEX my_composite_index ON my_table (column1, column2);
Indeks ini memastikan keunikan gabungan nilai dalam lajur1 dan lajur2.
Menggunakan KEMASKINI PADA KUNCI DUA
Dengan kunci komposit dipasang, anda kini boleh menggunakan KEMASKINI PADA DUPLICATE KEY untuk melaksanakan operasi yang diingini:
INSERT INTO my_table (column1, column2) VALUES ('value1', 'value2') ON DUPLICATE KEY UPDATE column3=column3+1;
Dalam contoh ini, baris dengan nilai lajur1 dan lajur2 'value1' dan 'value2' sama ada disisipkan atau dikemas kini, bergantung pada sama ada ia sudah wujud. Jika baris wujud, nilai lajur3 akan dinaikkan.
Kecekapan Prestasi
Dengan mencipta kunci komposit, anda mengelakkan keperluan untuk mencari mahal pada lajur individu. Pangkalan data boleh menentukan kewujudan atau ketiadaan baris dengan cepat berdasarkan kunci komposit, menghasilkan prestasi pertanyaan yang lebih baik.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengoptimumkan Pertanyaan MySQL untuk Kemas Kini dan Sisipan Berdasarkan Kekunci Berbilang Lajur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!