MySQL數(shù)據(jù)庫中,id自動遞增是一種十分常見的需求。大多數(shù)情況下,每次新增一條記錄時,都需要為該記錄生成一個唯一的id,以便于標識該記錄。而自動遞增的id可以為我們省去手動為每條記錄分配id的麻煩。
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
在MySQL中,我們可以使用AUTO_INCREMENT關鍵字來指定id自動遞增。在上述表定義中,我們?yōu)閕d列指定了AUTO_INCREMENT屬性,并將初始值設為1。這意味著當我們往user表中插入一條記錄時,id列的值將自動遞增,從1開始每次增加1。
同時,我們還可以使用LAST_INSERT_ID()函數(shù)獲取剛剛插入記錄的id值。這個函數(shù)會返回上一個INSERT語句所插入的id值,因此我們可以在新增記錄后直接調(diào)用該函數(shù)來獲取新增記錄的id。
INSERT INTO `user` (`name`, `age`) VALUES ('張三', 18); SELECT LAST_INSERT_ID();
總之,id自動遞增是一種非常方便的功能,它能夠為我們省去手動分配id的麻煩,并且在許多場景下都可以大大提高我們的工作效率。