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

Bagaimana untuk Melaksanakan Kunci Utama Auto-Lajur Berbilang Lajur dalam MySQL?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-11 10:43:10671semak imbas

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

Menggunakan Kunci Utama Auto-Tambahan Berbilang Lajur dengan Auto-Tambahan pada Lajur Kedua

Mengekalkan integriti data dalam pangkalan data dengan struktur dikongsi boleh penting. Sebagai sebahagian daripada strategi anda, anda sedang mempertimbangkan untuk menggunakan dua lajur sebagai kunci utama bersama, satu sebagai pengecam pangkalan data dan satu lagi kunci jadual. Walau bagaimanapun, anda ingin menetapkan kekunci jadual kepada kenaikan automatik berdasarkan pengecam pangkalan data.

Untuk MySQL, anda mempunyai pilihan bergantung pada enjin storan yang anda gunakan. Jika anda menggunakan MyISAM, anda boleh memanfaatkan keupayaannya untuk menentukan AUTO_INCREMENT pada lajur kedua dalam indeks berbilang lajur.

Untuk memahami cara ini berfungsi, pertimbangkan contoh berikut:

CREATE TABLE animals (
    grp ENUM('fish','mammal','bird') NOT NULL,
    id MEDIUMINT NOT NULL AUTO_INCREMENT,
    name CHAR(30) NOT NULL,
    PRIMARY KEY (grp,id)
) ENGINE=MyISAM;

Dalam jadual ini, lajur grp dan id membentuk kunci utama komposit. Lajur id sedang meningkat secara automatik, tetapi pengiraan nilainya mengambil kira awalan (dalam kes ini, nilai grp).

Menggunakan konsep ini pada senario anda:

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;

Memasukkan data sampel :

INSERT INTO mytable (database_id, other_column) VALUES
    (1,'Foo'),(1,'Bar'),(2,'Baz'),(1,'Bam'),(2,'Zam'),(3,'Zoo');

Menyoal jadual:

SELECT * FROM mytable ORDER BY database_id,table_id;

Ini akan mengembalikan hasil yang dikumpulkan mengikut database_id dengan nilai table_id yang ditambah secara automatik untuk setiap kumpulan.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Kunci Utama Auto-Lajur Berbilang Lajur 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