MySQL中InnoDB 表的 自增(AUTO_INCREMENT )列详解

2024-01-28 18:28

本文主要是介绍MySQL中InnoDB 表的 自增(AUTO_INCREMENT )列详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

innodb表必须将 AUTO_INCREMENT 列定义为某个索引的第一个或唯一列。建议将 AUTO_INCREMENT 列设置为 PRIMARY KEY(主键)或 UNIQUE(唯一键)索引的一部分,以防止出现重复值

InnoDB AUTO_INCREMENT 锁模式

InnoDB 使用不同的锁模式来生成自增值:

innodb_autoinc_lock_mode =0traditional
  • 在这种模式下,InnoDB使用类似于MyISAM存储引擎的锁定策略。
  • 对于包含自增列的每个INSERT语句,InnoDB会对表加上排他锁(auto-inc锁),直到当前语句完成才释放。
  • 这是最安全的模式,因为它可以保证在任何情况下都不会生成重复的自增值。
  • 但由于需要持续地获取和释放锁,所以可能会导致性能问题,特别是在高并发的插入操作时。
innodb_autoinc_lock_mode =1consecutive
  • 这种模式针对单个INSERT操作仍然使用锁,但如果是批量插入(比如INSERT ... SELECT或者LOAD DATA INFILE),则采用不同的策略,只在批量插入开始时获取一次锁,然后计算出所有行所需的自增值范围,接着释放锁。
  • 这种模式可以减少锁的竞争,提高并发插入的性能,同时依旧保证不会产生重复的自增值。
  • 是MySQL 5.1版本以后的默认设置。
innodb_autoinc_lock_mode =2interleaved
  • 在这种模式下,InnoDB不会对自增列使用表级锁。
  • 自增值的分配是在每行插入的时候动态进行的,而不是预先计算出一个范围。
  • 这种模式允许高度并发的插入操作,因为不同的事务可以同时插入数据而不会等待其他事务释放自增锁。
  • 但在某些场合,比如复制环境或者某些类型的备份操作中,可能会产生间隔的自增值,因此它适用于那些对自增值连续性没有要求的场景。
  • 需要注意的是,在这种模式下,如果发生回滚,已经分配的自增值将不会被回收,可能会存在自增值的跳跃。
  • 是MySQL 8.0版本以后的默认设置。

MySQL 8.0 默认使用交错锁模式(2),反映了从基于语句的复制默认更改为基于行的复制。

AUTO_INCREMENT 计数器初始化
  • MySQL 5.7 及更早版本在内存中存储自增计数器;服务器重启后,使用 SELECT MAX(ai_col) FROM table_name FOR UPDATE 初始化。
  • MySQL 8.0 中,自增计数器值写入重做日志并在每次检查点保存到数据字典,使得值在服务器重启后持久。
  • 在正常关闭后的服务器重启,或者在崩溃恢复过程中,InnoDB 使用数据字典中的当前最大自增值初始化内存中的计数器。
  • 如果没有 .cfg 元数据文件导入表,则还是会使用 SELECT MAX(ai_col) 来初始化计数器值。

注意

  • 修改 AUTO_INCREMENT 列的值或设置 ALTER TABLE ... AUTO_INCREMENT = N 只能将自增计数器值更改为当前最大值以上的值。
AUTO_INCREMENT 锁模式使用影响
  • 基于语句的复制时,应将 innodb_autoinc_lock_mode 设置为 0 或 1,并在源服务器和副本上使用相同的值。
  • 在基于行或混合格式复制中,所有自增锁模式都是安全的。

其他注意事项

  • 在任何锁模式下,回滚事务生成的自增值都将“丢失”,且不会被重用。
  • 在所有锁模式下,如果用户为 AUTO_INCREMENT 列指定 NULL 或 0,InnoDB 将为其生成新值。
  • 如果 AUTO_INCREMENT 值超过指定整数类型的最大值,自增机制的行为是未定义的。
  • 对于“混合模式插入”,不同的锁模式有不同的结果,如上所述的例子所示。
设置自增列的相关变量
  • auto_increment_offset 决定 AUTO_INCREMENT 列值的起始点,默认为 1。
  • auto_increment_increment 控制连续列值之间的间隔,默认为 1。

这篇关于MySQL中InnoDB 表的 自增(AUTO_INCREMENT )列详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/654428

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优