MySQL 中自增列是一種非常有用的特性,它可以自動(dòng)為表中的新增數(shù)據(jù)分配遞增的唯一標(biāo)識(shí)。我們不必手動(dòng)為新行指定 id ,而是讓 MySQL 來(lái)托管這個(gè)任務(wù)。
其中一個(gè)問(wèn)題是,如果您在插入新行時(shí)不給自增列提供值,MySQL 如何確保為該列生成一個(gè)唯一的值呢?
CREATE TABLE users ( id INT(11) UNSIGNED AUTO_INCREMENT, name VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
在上面的示例中,我們有一個(gè)名為 id 的自增列,當(dāng)我們向 users 表中插入新行時(shí),MySQL 會(huì)為每個(gè)新行生成一個(gè)唯一的 id 值。但是,如果我們不顯式地對(duì) id 列賦值,MySQL 會(huì)自動(dòng)將其設(shè)置為 NULL。
在實(shí)際操作中,我們可以總是提供一個(gè) NULL 值,但是這樣一來(lái),我們就失去了自增列的好處。因此,MySQL 提供了一個(gè)解決方案。當(dāng)您在插入新行時(shí)不提供自增列的值時(shí),MySQL 會(huì)將其設(shè)置為下一個(gè)可用的值。
此時(shí),如果您在表中手動(dòng)插入行并為自增列提供值,MySQL 可能會(huì)遇到主鍵沖突。我們需要特別注意這個(gè)問(wèn)題。