Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Melaksanakan Kunci Utama Dua Lajur dengan Auto-Peningkatan dalam MySQL?

Bagaimana untuk Melaksanakan Kunci Utama Dua Lajur dengan Auto-Peningkatan dalam MySQL?

Patricia Arquette
Lepaskan: 2024-12-08 08:59:11
asal
853 orang telah melayarinya

How to Implement a Two-Column Primary Key with Auto-Increment in MySQL?

MySql: Mengkonfigurasi Kunci Utama Dua Lajur dengan Ciri Peningkatan Auto

Konteks dan Pernyataan Masalah

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.

Penyelesaian dalam MySql

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;
Salin selepas log masuk

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');
Salin selepas log masuk

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          |
+----------+-------------+--------------+
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan