MySQL中id的生成策略一直是非常重要的話題,尤其是當(dāng)我們需要處理大數(shù)據(jù)量的時候。下面我們將簡單介紹MySQL中三種常見的id生成方式:
1. 自增長id:
CREATE TABLE test (
id INT UNSIGNED NOT NULL AUTO_INCREMENT,
name VARCHAR(30) NOT NULL,
age TINYINT UNSIGNED NOT NULL,
PRIMARY KEY (id)
);
這種方式的優(yōu)點(diǎn)是非常簡單明了,而且對于大部分應(yīng)用場景來說,足以滿足需求。但當(dāng)數(shù)據(jù)集非常大的時候,這種方式有可能會導(dǎo)致id值用完,再次使用的時候要分配更大的空間。
2. UUID:
CREATE TABLE test (
id CHAR(36) NOT NULL PRIMARY KEY DEFAULT (UUID());
);
這種方式的優(yōu)點(diǎn)在于能夠很好的避免id沖突的問題,而且在分布式系統(tǒng)環(huán)境下也可以使用。但缺點(diǎn)也很明顯,由于id值非常長,當(dāng)數(shù)據(jù)集非常大時,需要占用很大的空間。
3. snowflake算法:
CREATE TABLE test (
id BIGINT UNSIGNED NOT NULL PRIMARY KEY DEFAULT (SELECT next_id() FROM tbl_sequencer WHERE name='test');
);
snowflake算法是Twitter開源的一種分布式自增id生成算法,可以支持高并發(fā)場景的id生成。它的優(yōu)點(diǎn)在于能夠生成非常長的id序列,而且避免了自增id的缺陷。但它的復(fù)雜程度也很高,需要一定的技術(shù)能力。