Mengekalkan Auto-Tambahan dan Menggunakan Lajur Lain sebagai Kunci Utama dalam MySQL
Dalam MySQL, apabila mencipta jadual dengan lajur auto-increment , tingkah laku lalai adalah untuk lajur itu juga menjadi kunci utama. Walau bagaimanapun, tingkah laku ini boleh membawa kepada isu prestasi jika pertanyaan mengenal pasti baris terutamanya menggunakan lajur yang berbeza.
Pertimbangkan senario berikut: anda mencipta jadual dengan lajur bernama id sebagai kunci utama kenaikan automatik dan lajur lain bernama memberid yang unik dan digunakan dalam pertanyaan untuk mengenal pasti ahli. Dalam kes ini, adalah sesuai untuk menggunakan memberid sebagai kunci utama atas sebab prestasi, tetapi berbuat demikian akan menyebabkan ralat:
1075 - Incorrect table definition; there can be only one auto column and it must be defined as a key
Untuk menangani perkara ini, penyelesaian terbaik ialah mengekalkan lajur id untuk mengekalkan fungsi auto-increment sambil mentakrifkan memberid sebagai kunci utama. Ini boleh dicapai dengan mencipta indeks (kunci) pada lajur id, seperti yang ditunjukkan di bawah:
CREATE TABLE members ( id int(11) UNSIGNED NOT NULL AUTO_INCREMENT, memberid VARCHAR( 30 ) NOT NULL , `time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP , firstname VARCHAR( 50 ) NULL , lastname VARCHAR( 50 ) NULL , PRIMARY KEY (memberid) , KEY (id) --- or: UNIQUE KEY (id) ) ENGINE = MYISAM;
Pendekatan ini membolehkan anda mengekalkan lajur peningkatan automatik untuk tujuan prestasi sementara masih menggunakan memberid sebagai yang utama kunci untuk pertanyaan yang cekap.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Lajur Berbeza sebagai Kunci Utama Semasa Mengekalkan Peningkatan Auto dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!