Dalam senario di mana berbilang pangkalan data mempunyai struktur yang serupa dan data mesti dikekalkan di seluruh mereka, menjaga integriti data adalah penting. Menggunakan kunci utama dua lajur terbukti bermanfaat dalam hal ini. Satu lajur, mewakili ID pangkalan data, mewujudkan sambungan ke jadual yang mengandungi maklumat khusus pangkalan data. Satu lagi lajur, kunci jadual, mempunyai atribut bukan keunikan tetapi memudahkan pembezaan baris melalui lajur ID pangkalan data.
Matlamatnya adalah untuk menyertai dua lajur sebagai kunci utama sambil mengautomasikan kenaikan kunci jadual secara serentak berdasarkan lajur ID pangkalan data.
Untuk MySql, penyelesaian wujud untuk memenuhi keperluan ini:
1. Menggunakan Enjin Storan MyISAM:
Permit MySql menyatakan AUTO_INCREMENT pada lajur sekunder dalam indeks berbilang lajur, di bawah enjin storan MyISAM. Ciri ini membolehkan penjanaan nilai secara automatik untuk lajur AUTO_INCREMENT menggunakan formula: MAX(auto_increment_column) 1 WHERE awalan=awalan-diberikan.
2. Contoh Pelaksanaan:
Sebagai contoh, pertimbangkan skema berikut:
CREATE TABLE mytable ( table_id MEDIUMINT NOT NULL AUTO_INCREMENT, database_id MEDIUMINT NOT NULL, other_column CHAR(30) NOT NULL, PRIMARY KEY (database_id,table_id) ) ENGINE=MyISAM;
3. Keputusan:
Memasukkan data ke dalam jadual ini, dengan sampel ID pangkalan data dan data lain, menunjukkan tingkah laku kenaikan automatik:
INSERT INTO mytable (database_id, other_column) VALUES (1,'Foo'),(1,'Bar'),(2,'Baz'),(1,'Bam'),(2,'Zam'),(3,'Zoo');
Mengambil semula data mendedahkan kenaikan kunci jadual automatik berdasarkan ID pangkalan data:
SELECT * FROM mytable ORDER BY database_id,table_id; +----------+-------------+--------------+ | table_id | database_id | other_column | +----------+-------------+--------------+ | 1 | 1 | Foo | | 2 | 1 | Bar | | 3 | 1 | Bam | | 1 | 2 | Baz | | 2 | 2 | Zam | | 1 | 3 | Zoo | +----------+-------------+--------------+
Dengan menggunakan enjin storan MyISAM dan memahami mekanik penambahan automatik di bawah kunci utama berbilang lajur, pendekatan ini memastikan integriti data dan pengurusan data yang dipermudahkan.
Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Kunci Utama Dua Lajur dengan Auto-Peningkatan dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!