MySQL是一種非常流行的數(shù)據(jù)庫(kù)管理系統(tǒng),在大多數(shù)的應(yīng)用程序中用得非常廣泛。但是,有些人可能不知道的是,MySQL沒(méi)有內(nèi)置的序列對(duì)象(sequence object)。
CREATE SEQUENCE seq_name;
在許多其他的數(shù)據(jù)庫(kù)管理系統(tǒng)中,序列對(duì)象是一種常見(jiàn)的機(jī)制,可以用來(lái)生成唯一的數(shù)值類型的對(duì)應(yīng)值。例如,Oracle、PostgreSQL 和 SQL Server 都有序列的概念。作為替代方案,MySQL 使用 AUTO_INCREMENT 屬性來(lái)生成唯一的鍵值。
CREATE TABLE example_table ( id INT(11) NOT NULL AUTO_INCREMENT, name VARCHAR(50) NOT NULL, PRIMARY KEY (id) ); INSERT INTO example_table (name) VALUES ('foo'); INSERT INTO example_table (name) VALUES ('bar'); INSERT INTO example_table (name) VALUES ('baz');
當(dāng)我們執(zhí)行 INSERT 語(yǔ)句時(shí),MySQL 會(huì)檢查表中是否定義了一個(gè) AUTO_INCREMENT 列。如果是,MySQL 會(huì)把下一個(gè)可用的唯一數(shù)值賦給列(編號(hào)列)。 MySQL 通過(guò)內(nèi)部機(jī)制來(lái)維護(hù)這個(gè)值,而不是使用一個(gè)序列對(duì)象。
雖然沒(méi)有直接使用序列對(duì)象的方法,但是 AUTO_INCREMENT 還是可以起到同樣的作用。