广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中的主键自增机制详情
  • 877
分享到

MySQL中的主键自增机制详情

2024-04-02 19:04:59 877人浏览 八月长安
摘要

目录主键自增自增主键保存在哪里自增值修改机制自增值的修改时机如何修改自增主键值主键自增 Mysql 提供了主键自增机制 AUTO_INCREMENT. 对主键使用, 保证了主键的唯一性. 注意:自增长必须与主键字段配合使

主键自增

Mysql 提供了主键自增机制 AUTO_INCREMENT. 对主键使用, 保证了主键的唯一性.

注意:自增长必须与主键字段配合使用

默认的主键的起始值为 1, 每次增量为 1, 也可以手动指定其自增起始值 auto_increment_offset 和自增步长 auto_increment_increment.

-- 设置主键自增
CREATE TABLE USER(
    id INT UNSIGNED AUTO_INCREMENT,
    ...
)

-- 在创建表时指定自增起始值
CREATE TABLE xx{

}ENGINE=INNODB auto_increment=100 DEFAULT CHARSET=utf8;

-- 修改自增起始值
alter table people  AUTO_INCREMENT = 20;

-- 基于会话级别:
show session variables like 'auto_inc%';  -- 查看步长
set session auto_increment_increment=2;   -- 修改自增步长
  
-- 基于全局级别:(会影响下一次登录的值)
show global variables like 'auto_inc%'; 	-- 查看步长
set global auto_increment_increment=5;	-- 修改自增步长

注意:

  • 在 InnoDB 存储引擎中, 自增长值的列必须是索引, 同时必须是索引的第 1 个列. 如果不是第 1 个列, 则 mysql 数据库会抛出异常. 对于 MyISAM 无此要求。
  • 自增长每次递增 1, 说明是数值型, 可以是整数, 也可以是浮点数.
  • 由于种种原因, 自增值可以保证增长趋势, 但并不能保证连续.
  • 不会影响自增长的命令:DELETE FROM xxx;
  • 可以影响自增长的命令:TRUNCATE TABLE xxx;

使用起来倒是很简单,但是对于主键自增机制的这些问题,你了解吗?

  • 自增主键保存在哪里?
  • 自增主键如何实现自增的?
  • 自增主键是什么时候自增的?
  • 自增主键一定是连续自增的吗?
  • 自增主键可以人为修改吗?

自增主键保存在哪里

首先需要知道的是,自增主键机制是存储引擎实现的,所以不同的存储引擎对于自增值的保存策略不同.

  • MyISAM 的自增值保存在数据文件中.
  • InnoDB 的自增值, 保存在内存里, 一直到了 Mysql 8.0 后, 才有了自增值的持久化的能力, 也就是才保存到文件中,实现了如果发生重启, 表的自增值可以恢复为 MySQL 重启前的值.

具体是:在 MySQL <= 5.7 时, 自增值保存在内存里, 没有持久化. 当 MySQL 重启后, 第一次打开某个数据表的时候, 都会去找该表中主键字段的自增值的最大值 max(id), 然后将 max(id)+1 作为这个表当前的自增值.

但是这样就会存在一个问题,比如 :  如果一个表的 id 最大是 10, 此时的 AUTO_INCREMENT=11. 当删除 id=10 的记录时, 此时 AUTO_INCREMENT 还是 11. 但如果马上重启 MySQL, 重启后这个表的 AUTO_INCREMENT 就变为 10 了. ( maxid = 9, 9+1=10 )  即 MySQL 重启可能会修改表的 AUTO_INCREMENT 的值.

在 MySQL 8.0 版本, 将自增值的变更记录在了 redo log 中, 重启的时候依靠 redo log 恢复重启之前的值. 所以不会出现上述问题.

自增值修改机制

在 MySQL 中, 如果字段 id 被定义为 AUTO_INCREMENT, 在插入一行数据的时候, 自增值的操作如下:

  • 如果插入数据时, id 字段指定为 0, null 或未指定值, 那么就把这个表当前的 AUTO_INCREMENT 值给自增字段, ( 没给值, 则使用自增长值 )
  • 如果插入数据时, id 字段指定了具体的值, 就直接使用 SQL 语句里指定的值. ( 给定了值, 就使用给定值 )
  • 根据要插入的值和当前自增值的大小关系, 自增值的变更结果也会有所不同.

假设, 要插入的值是 X, 当前的自增值是 Y.

如果 X < Y, 那么这个表的自增值不变.

如果 X ≥ Y, 就需要把当前表的自增值修改为新的自增值. 新的自增值生成方式是:从 auto_increment_offset 开始, 以 auto_increment_increment 为步长, 持续叠加, 直到找到第一个大于 X 的值, 作为新的自增值.   也就是,这种情况下步长也参与了影响。

自增值的修改时机

假设, 有一个表 t , 有 A, B, C 三个字段, 字段 A 是主键, 且自增, 字段 C 有唯一约束.

当前表 t 中有一条记录为  (1,1,1) , 此时执行一条插入语句 insert into t values(null, 1, 1);

那么这个语句的执行流程就是:

  • 执行器调用 InnoDB 引擎的接口,写入一行, 传入的这一行的值是 (null,1,1);
  • InnoDB 发现用户没有指定自增 id 的值, 所以会获取表 t 当前的自增值 2,
  • 然后 InnoDB 会将传入的行的值改成 (2,1,1);
  • 然后将表的自增值改成 3,
  • 然后执行插入数据操作, 由于 C 字段已经存在 = 1 的记录, 所以报 Duplicate key error, 并返回.

最后的结果可以看到, 这个表的自增值改成 3, 是在真正执行插入数据的操作之前进行的.

这个语句真正执行的时候, 因为碰到唯一键 C 冲突, 所以 id=2 这一行并没有插入成功, 但也没有将自增值再改回去. 所以, 在这之后, 再插入新的数据行时, 拿到的自增 id 就是 3. 也就是说, 出现了自增主键不连续的情况.

总结自增主键不连续有如下两种情况 :

  • 唯一约束冲突导致自增主键不连续.
  • 事务回滚也会导致自增主键不连续.

如何修改自增主键值

有如下几种修改方式:

  • 使用alter table 表名 AUTO_INCREMENT = ?来修改自增值的起始值。
  • 在创建表时设置 AUTO_INCREMENT=? 自增值的起始值。

到此这篇关于MySQL中的主键自增机制详情的文章就介绍到这了,更多相关MySQL主键自增内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中的主键自增机制详情

本文链接: https://www.lsjlt.com/news/33865.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中的主键自增机制详情
    目录主键自增自增主键保存在哪里自增值修改机制自增值的修改时机如何修改自增主键值主键自增 mysql 提供了主键自增机制 AUTO_INCREMENT. 对主键使用, 保证了主键的唯一性. 注意:自增长必须与主键字段配合使...
    99+
    2022-08-26
  • 详解MySQL自增主键的实现
    目录一、自增值保存在哪儿?二、自增值修改机制三、自增值的修改时机四、自增锁的优化五、自增主键用完了一、自增值保存在哪儿? 不同的引擎对于自增值的保存策略不同 1.MyISAM引擎的自...
    99+
    2022-11-12
  • MySQL主键自增的原因
    MySQL主键自增的原因?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!InnoDB引擎表的特点1、InnoDB引擎表是基于...
    99+
    2022-10-18
  • Mysql 自增主键回溯的坑
    使用mysql的时候,很多时候用自增主键。正常使用一般是没有问题的,但是极小概率情况下会碰到主键回溯的问题。在业务上可能造成id一样,但是对应的业务数据不一样的问题。这个问题发生在Mysql 8.0版本之前。 出现场景: 插入一条数据返回主...
    99+
    2017-04-29
    Mysql 自增主键回溯的坑 数据库入门 数据库基础教程
  • 删除mysql中自增主键的方法
    小编给大家分享一下删除mysql中自增主键的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!删除mysql中的自增主键的方法:首先需要删除auto_increment;然后执行【alter ...
    99+
    2022-10-18
  • MySQL中自增主键的示例分析
    这篇文章主要介绍了MySQL中自增主键的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、自增值保存在哪儿?不同的引擎对于自增值的保...
    99+
    2022-10-18
  • MySQL中的自增主键怎么修改
    这篇文章主要介绍“MySQL中的自增主键怎么修改”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL中的自增主键怎么修改”文章能帮助大家解决问题。一、自增值保存...
    99+
    2022-10-19
  • mybatis实现oracle主键自增的机制是什么
    这篇文章主要介绍“mybatis实现oracle主键自增的机制是什么”,在日常操作中,相信很多人在mybatis实现oracle主键自增的机制是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2023-02-15
    mybatis oracle
  • mysql 中怎么实现主键自增长
    这篇文章将为大家详细讲解有关mysql 中怎么实现主键自增长,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。mysql表主键自增长的sql语句1、不控制主键的...
    99+
    2022-10-18
  • MySQL补充——获取自增主键的下一个自增值
    本文主要学习了如何获得自增主键的下一个值。 MySQL补充——获取自增主键的下一个自增值 摘要:本文主要学习了如何获得自增主键的下一个值。 格式 1 select auto_incremen...
    99+
    2017-05-27
    MySQL补充——获取自增主键的下一个自增值
  • Mysql中INNODB自增主键的问题有哪些
    小编给大家分享一下Mysql中INNODB自增主键的问题有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!背景: &nbs...
    99+
    2022-10-18
  • mysql中怎么实现主键自动增长
    本篇文章为大家展示了mysql中怎么实现主键自动增长,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、我们先建一个表usermysql> create tab...
    99+
    2022-10-18
  • Mysql主键UUID和自增主键的区别及优劣分析
    引言 之前有段时间用postgresql 数据库,在上云之后,从自增主键变为uuid,感觉uuid全球唯一,很方便。 最近用mysql,发现mysql主键都是选择自增主键,仔细比较一下,为什么mysql选择自增主键,...
    99+
    2022-06-01
    Mysql 主键UUID 自增主键
  • MySql手动获取自增主键的方法
    小编给大家分享一下MySql手动获取自增主键的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!mysql手动获取自增主键的方法...
    99+
    2022-10-18
  • 解决mysql的int型主键自增问题
    引入 我们在使用mysql数据库时,习惯使用int型作为主键,并设置为自增,这既能够保证唯一,使用起来又很方便,但int型的长度是有限的,如果超过长度怎么办呢? 暴露问题 我们先创建...
    99+
    2022-11-12
  • 怎么在mysql中实现非主键自增长
    怎么在mysql中实现非主键自增长?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。mysql并非只有主键才能自增长,而是设为键的列就可以设置自增...
    99+
    2022-10-18
  • 浅谈MySQL中的自增主键用完了怎么办
    在面试中,大家应该经历过如下场景 面试官:"用过mysql吧,你们是用自增主键还是UUID?"    你:"用的是自增主键"     面试官:"为什么是自增主键?" &nbs...
    99+
    2022-05-21
    MySQL 自增主键用完 MySQL 自增主键
  • Mysql更新自增主键id遇到的问题
    目录为什么要更新自增id问题如何解决本是一个自己知道的问题,还是差点踩坑(差点忘了,还好上线前整理上线点时想起来了),特此记录下来 为什么要更新自增id 我是因为历史业务上的坑,导致...
    99+
    2022-11-12
  • 为什么mysql自增主键不是连续的
    目录一 前言二 自增值存储说明三 自增值修改机制四 自增值修改时机五 导致自增值不连续的原因5.1 唯一键冲突5.2 事务回滚5.3 批量写库操作六 参考文档 一...
    99+
    2022-11-12
  • Mysql自增主键id不是以此逐级递增的处理
    Mysql自增主键id不是以此逐级递增 一、介绍 在mysql数据库添加数据时使用ON DUPLICATE KEY UPDATE进行数据更新时可能会出现id不是逐级以此递增的,而是间...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作