MySQL如何让一个表中可以有多个自增列

 更新时间:2022年06月22日 10:02:00   作者:​ Java中文社群   ​  
这篇文章主要介绍了MySQL如何让一个表中可以有多个自增列,自增列可使用 auto_increment 来实现,当一个列被标识为 auto_increment 之后,在添加时如果不给此列设置任何值,或给此列设置 NULL 值时,那么它会使用自增的规则来填充此列

前言:

自增列可使用 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.其他注意事项

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

4.1 自增列只能为整数类型

自增列的字段类型只能为整数类型(TINYINT、SMALLINT、INT、BIGINT 等),

如下图所示: 

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

4.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。

到此这篇关于MySQL如何让一个表中可以有多个自增列的文章就介绍到这了,更多相关MySQL表自增列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL外键约束的禁用与启用命令

    MySQL外键约束的禁用与启用命令

    下面小编就为大家带来一篇MySQL外键约束的禁用与启用命令。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • MySQL binlog中的事件类型详解

    MySQL binlog中的事件类型详解

    这篇文章主要介绍了MySQL binlog中的事件类型详解,介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • 在MySQL中使用GTIDs复制协议和中断协议的教程

    在MySQL中使用GTIDs复制协议和中断协议的教程

    这篇文章主要介绍了在MySQL中使用GTIDs复制协议和中断协议的教程,主要用于多个服务器之间的通信,需要的朋友可以参考下
    2015-04-04
  • Mysql的Explain使用方式及索引总结

    Mysql的Explain使用方式及索引总结

    这篇文章主要介绍了Mysql的Explain使用方式及索引总结,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • MySQL 使用 ORDER BY 排序和 DELETE 删除记录的操作过程

    MySQL 使用 ORDER BY 排序和 DELETE 删

    这篇文章主要介绍了MySQL 使用 ORDER BY 排序和 DELETE 删除记录的操作过程,即数据库查询与数据操作,本文通过示例代码给大家介绍的非常详细,需要的朋友参考下吧
    2023-11-11
  • mysql是否需要容器化深入分析

    mysql是否需要容器化深入分析

    这篇文章主要为大家介绍了mysql是否需要容器化深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)

    MySQL中的 inner join 和 left join的区别解析

    这篇文章主要介绍了MySQL中的 inner join 和 left join的区别解析,本文通过场景描述给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • MySQL 一则慢日志监控误报的问题分析与解决

    MySQL 一则慢日志监控误报的问题分析与解决

    这篇文章主要介绍了MySQL 一则慢日志监控误报的问题分析与解决,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下
    2021-01-01
  • CentOS系统下编译安装MySQL以及设置相关yum源的教程

    CentOS系统下编译安装MySQL以及设置相关yum源的教程

    这篇文章主要介绍了CentOS系统下编译安装MySQL以及设置相关yum源的教程,使用RedHat系的Linux系统为环境的都可以借鉴,需要的朋友可以参考下
    2015-12-12
  • 关于mysql调用新手们常犯的11个错误总结

    关于mysql调用新手们常犯的11个错误总结

    对于很多新手们来说,使用PHP可以在短短几个小时之内轻松地写出具有特定功能的代码。但是,构建一个稳定可靠的数据库却需要花上一些时日和相关技能。下面这篇文章就来总结了关于mysql调用新手们常犯的十一个错误,需要的朋友可以参考学习。
    2017-03-03

最新评论