MySQL AUTO_INCREMENT:主键自增长
通过给字段添加 AUTO_INCREMENT 属性来实现主键自增长。语法格式如下:
字段名 数据类型 AUTO_INCREMENT
默认情况下,AUTO_INCREMENT 的初始值是 1,每新增一条记录,字段值自动加 1。
一个表中只能有一个字段使用 AUTO_INCREMENT 约束,且该字段必须有索引,以避免序号重复(即为主键或主键的一部分)。
AUTO_INCREMENT 约束的字段必须具备 NOT NULL 属性。
- AUTO_INCREMENT 约束的字段只能是整数类型(TINYINT、ALLINT、INT、BIGINT 等)。
AUTO_INCREMENT 约束字段的值受该字段的数据类型约束,如果达到上限,AUTO_INCREMENT 就会失效。
例 1
定义数据表 tb_student,指定表中 id 字段递增,SQL 语句和运行结果如下:
上述语句执行成功后,会创建名为 tb_student 的数据表。其中,id 为主键,每插入一条新记录,id 的值就会在前一条记录的基础上自动加 1。name 为非空字段,该字段的值不能为空值(NULL)。mysql> CREATE TABLE tb_student(
-> id INT(4) PRIMARY KEY AUTO_INCREMENT,
-> name VARCHAR(25) NOT NULL
-> );
Query OK, 0 rows affected (0.07 sec)
向 tb_student 表中插入数据,SQL 语句如下所示:
语句执行完后,tb_student 表中增加了 3 条记录,在这里并没有输入 id 的值,但系统已经自动添加该值,使用 SELECT 令查看记录,如下所示。INSERT INTO tb_student(name) VALUES('Java')('MySQL')('Python');
mysql> SELECT * FROM tb_student;
+----+--------+
| id | name |
+----+--------+
| 1 | Java |
| 2 | MySQL |
| 3 | Python |
+----+--------+
4 rows in set (0.01 sec)
拓展
加上 AUTO_INCREMENT 约束条件后,字段中的每个值都是自动增加的。因此,这个字段不可能出现相同的值。通常情况下,AUTO_INCREMENT 都是作为 id 字段的约束条件,并且将 id 字段作为表的主键。指定自增字段初始值
如果条记录设置了该字段的初始值,那么新增加的记录就从这个初始值开始自增。例如,如果表中插入的条记录的 id 值设置为 5,那么再插入记录时,id 值就会从 5 开始往上增加。
例 2
下面创建表 tb_student2,指定主键从 100 开始自增长。SQL 语句和运行结果如下:
向 tb_student2 表中插入数据,并使用 SELECT 令查询表中记录。mysql> CREATE TABLE tb_student2 (
-> id INT NOT NULL AUTO_INCREMENT,
-> name VARCHAR(20) NOT NULL,
-> PRIMARY KEY(ID)
-> )AUTO_INCREMENT=100;
Query OK, 0 rows affected (0.03 sec)
mysql> INSERT INTO tb_student2 (name)VALUES('Java');
Query OK, 1 row affected (0.07 sec)
mysql> SELECT * FROM tb_student2;
+-----+------+
| id | name |
+-----+------+
| 100 | Java |
+-----+------+
由结果可以看出,id 值从 100 开始自动增长。
自增字段值不连续
下面我们通过一个实例分析自增字段的值为什么不连续。例 3
创建表 tb_student3,其中 id 是自增主键字段,name 是索引,SQL 语句和执行结果语句如下:mysql> CREATE TABLE tb_student3(
-> id INT PRIMARY KEY AUTO_INCREMENT,
-> name VARCHAR(20) UNIQUE KEY,
-> age INT DEFAULT NULL
-> );
Query OK, 0 rows affected (0.04 sec)
向 tb_student3 表中插入数据,SQL 语句如下:
INSERT INTO tb_student3 VALUES(1,1,1);
此时,表 tb_student3 中已经有了(1,1,1)这条记录,这时再执行一条插入数据令:
mysql> INSERT INTO tb_student3 VALUES(null,1,1);
ERROR 1062 (23000): Duplicate entry '1' for key 'name'
由于表中已经存在 name=1 的记录,所以报 Duplicate key error(键冲突)。在这之后,再插入新的数据时,自增 id 就是 3,这样就出现了自增字段值不连续的情况。
- 随机文章
- 核心危机(核心危机魔石合成攻略)
- 儿童教育文章(儿童教育)
- 光遇花手先祖位置(安卓光遇手花先祖)
- 广州4a广告公司(广州4a广告公司创意总监年薪)
- 抖音卡(抖音卡顿怎么解决)
- xboxones(xboxone手柄怎么配对主机)
- 兵马俑(兵马俑介绍和历史背景)
- 帆船比赛(帆船比赛视频)
- 韩国媳妇和小雪(韩国媳妇和小雪的父亲工资是多少)
- 儋州市第二中学(儋州市第二中学录取分数线)
- 鬼泣5攻略(鬼泣5攻略第三关怎么跳)
- 地球日主题(2020年世界地球日主题)
- 和柳亚子(和柳亚子先生于田)
- 冰客(冰客果汁)
- yy魔兽(yy魔兽世界)
- 国外成人游戏(国外成人游戏注册需要visa信用卡)
- 充值卡代理(充值卡代理加盟)
- 拆奶罩
- 郭妮小说(恶魔的法则郭妮小说)
- 大松电饭煲(美的大松电饭煲)
- 服饰加盟(服饰加盟店招商)
- 疯狂填字(疯狂填字5)
- 点对点短信息(点对点短信息费是什么意思)
- 观音普门品(观音普门品念诵全文)
- 河北省大运会(河北省大运会时间)
- 哈利波特官网(哈利波特官网在哪里)
- 骇客神条(骇客神条怎么辨别真假)
- 杜星霖(杜星霖图片)
- 查传倜(查传倜个人生活)
- 广州晓港公园(广州晓港公园正门图片)
