Rumah  >  Artikel  >  pangkalan data  >  Bagaimanakah Saya Boleh Menggunakan Lajur Berbeza sebagai Kunci Utama Semasa Mengekalkan Peningkatan Auto dalam MySQL?

Bagaimanakah Saya Boleh Menggunakan Lajur Berbeza sebagai Kunci Utama Semasa Mengekalkan Peningkatan Auto dalam MySQL?

Susan Sarandon
Susan Sarandonasal
2024-11-03 16:02:03654semak imbas

How Can I Use a Different Column as Primary Key While Maintaining Auto-Increment in MySQL?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn