社区编辑申请
注册/登录
面试突击:一个表中可以有多个自增列吗?
数据库 MySQL
自增列的值默认是 1,每次递增 1,但也可以在创建表的时候手动指定自增值,当然在特殊情况下我们在表被创建之后,也可以通过 alter 修改自增值。

作者 | 磊哥

来源 | Java面试真题解析(ID:aimianshi666)

转载请联系授权(微信ID:GG_Stone)

自增列可使用 auto_increment 来实现,当一个列被标识为 auto_increment 之后,在添加时如果不给此列设置任何值,或给此列设置 NULL 值时,那么它会使用自增的规则来填充此列。

PS:本文以下内容基于 MySQL InnoDB 数据库引擎。

默认情况下自增列的值为 1,每次递增 1,比如以下建表 SQL:

create table tab_incre(
id int primary key auto_increment,
name varchar(250) not null
);

图片

我们在添加时,不给自增列 id 设置任何值,它的执行结果如下:

图片

图片从上述结果可以看出自增列默认值为 1,每次递增 1。

1、手动指定自增值

在创建表的时候可以手动指定自增值,如果不指定自增值,那么它默认会使用 1 作为自增值,手动指定自增值的 SQL 命令如下:

create table tab_incre(
id int primary key auto_increment,
name varchar(250) not null
) auto_increment=50;

图片

图片使用“show create table table_name”可以查看表中自增列的自增列值,如下图所示:

图片

图片此表的自增值为 50,我们也可以创建一条数据来验证一下自增值是否为 50,如下图所示:图片

图片

2、手动修改自增值

当表创建之后,我们也可以通过 alter 命令来修改自增列的值,它的修改命令如下:

alter table table_name auto_increment=n;

如果要将 tab_incre 表中的自增值修改为 100,可使用以下 SQL 来实现:

图片

注意事项

当我们试图将自增值设置为比自增列中的最大值还要小的值的时候,自增值会自动变为自增列的最大值 +1 的值,如下图所示:

图片

3、一个表可以有多个自增列吗?

一个表中只能有一个自增列,这和一个表只能有一个主键的规则类似,当我们尝试给一个表添加一个自增列时,可以正常添加成功,如下图所示:

图片

图片当我们尝试给一个表添加多个自增列时,会提示只能有一个自增列的报错信息,如下图所示:图片

图片

4、其他注意事项

除了一个表只能添加一个自增列之外,自增列还需要注意以下两个问题。

(1)自增列只能为整数类型

自增列的字段类型只能为整数类型(TINYINT、SMALLINT、INT、BIGINT 等),如下图所示:

图片

图片当我们使用其他类型来作为自增列的数据类型时,会提示如下错误:

图片图片

(2)必须配合 key 一起使用

auto_increment 必须配合 key 一起使用,这个 key 可以是 primary key 或 foreign key,如果没有 key 就会报错,如下所示:

图片

PS:auto_increment 也可以配合唯一约束 unique 一起使用。

总结

自增列的值默认是 1,每次递增 1,但也可以在创建表的时候手动指定自增值,当然在特殊情况下我们在表被创建之后,也可以通过 alter 修改自增值。一个表中只能有一个自增列,就像一个表中只能有一个主键一样,如果设置多个自增列,那么 SQL 执行就会报错。除此之外还要注意自增列应该为整数类型,且 auto_increment 需要配合 key 一起使用,这个 key 可以是 primary key 或 foreign key。

责任编辑:姜华 来源: Java面试真题解析
相关推荐

2022-06-20 22:37:25

Linux操作系统命令

2022-06-14 08:01:43

数据库MySQL

2022-06-06 07:35:26

2022-05-30 07:34:33

2022-06-27 17:46:53

PythonFlask

2022-06-13 07:36:06

2022-06-29 09:19:09

静态代码C语言c代码

2022-06-28 12:35:21

DockerPython

2022-06-28 09:26:25

Python配置文件

2022-06-28 10:58:35

勒索软件攻击事件

2022-06-28 09:34:24

可视化Python代码

2022-06-22 09:19:55

HDC鸿蒙ADB命令

2022-06-20 13:34:46

漏洞网络攻击

2022-06-23 12:03:00

网络安全网络安全事故

2022-06-16 07:32:38

VSCodePython插件

2022-06-27 08:07:13

Go语言互斥锁

2022-06-30 10:22:26

K8s可观测Prometheus

2022-06-30 10:56:18

字节云数据库存储

2022-06-29 10:16:25

数据库SQL

2022-06-22 05:53:49

城域网广域网VXLAN

同话题下的热门内容

一次非常有意思的 SQL 优化经历:从 30248.271s 到 0.001s解决MySQL幻读的终极指南面试突击:说一下MySQL事务隔离级别?为什么MySQL的count()方法这么慢?为什么SQL语句命中索引比不命中索引要快?面试突击:什么情况会导致 MySQL 索引失效?MySQL 索引失效的几种类型以及解决方式DBA技术分享-MySQL外键查询语句

编辑推荐

MySQL集群搭建详解如果对MySQL还停留在这个印象,就out了防止服务器宕机时MySQL数据丢失的几种方案MySQL innodb引擎备份工具XtraBackup之二(数据库全备)MySQL优化: Slave延迟很大的优化方法总结
我收藏的内容
点赞
收藏

51CTO技术栈公众号