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

作者:??Java中文社群???? 时间:2024-01-15 03:41:07 

前言:

自增列可使用 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
);

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

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

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

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

1.手动指定自增值

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

手动指定自增值的 SQL 命令如下:

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

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

 使用“show create table table_name”可以查看表中自增列的自增列值,

如下图所示: 

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

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

如下图所示: 

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

2.手动修改自增值

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

alter table table_name auto_increment=n;

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

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

注意事项:

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

如下图所示: 

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

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

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

如下图所示: 

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

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

如下图所示:

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

4.其他注意事项

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

4.1 自增列只能为整数类型

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

如下图所示: 

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

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

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

4.2 必须配合 key 一起使用

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

如下所示: 

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

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

来源:https://juejin.cn/post/7111839186340020237

标签:MySQL,表,自增列
0
投稿

猜你喜欢

  • MySQL中连接查询和子查询的问题

    2024-01-19 04:27:32
  • Vue-Element-Admin前端接入SSO的方法步骤

    2023-07-02 16:57:19
  • Python中赋值运算符的含义与使用方法

    2022-05-21 12:13:45
  • Python eval函数原理及用法解析

    2021-04-29 05:17:18
  • 超简单的Python HTTP服务

    2023-01-22 06:19:15
  • 用python实现爬取奥特曼图片实例

    2022-09-23 00:25:18
  • 解决ele ui 表格表头太长问题的实现

    2024-05-13 09:44:00
  • 对dataframe进行列相加,行相加的实例

    2023-07-24 16:57:59
  • PHP 图片上传代码

    2024-05-22 10:05:49
  • python 文件操作删除某行的实例

    2022-09-21 12:15:18
  • pycharm实现设置自动的参数注释标识

    2023-11-25 10:26:23
  • 在Python的Django框架中为代码添加注释的方法

    2023-09-25 07:24:21
  • python树的同构学习笔记

    2022-10-23 02:06:29
  • python 的 openpyxl模块 读取 Excel文件的方法

    2023-02-23 14:41:56
  • CSS滤镜示范(filter)附源代码(静态滤镜)

    2008-05-18 12:42:00
  • Git远程操作详解

    2022-02-11 06:15:51
  • python进阶教程之循环相关函数range、enumerate、zip

    2022-07-24 04:04:37
  • vue+element树组件 实现树懒加载的过程详解

    2024-05-25 15:19:36
  • SqlServer服务中利用触发器对指定账户进行登录ip限制提升安全性操作

    2024-01-26 12:24:32
  • MySql登录时闪退的快速解决办法

    2024-01-24 06:19:28
  • asp之家 网络编程 m.aspxhome.com