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。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/651629.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

递归神经网络:(01/4) 顺序数据处理的骨干

koushikkushal95 一、说明 循环神经网络是一个里程碑式的模型框架,它是对时间串处理的最基本构架;而理解RNN也是对自然语言处理模型的开端,本篇将对该模型的基本原理进行介绍。 二、顺序数据处理的架构 递归神经网络 (RNN&#xf…

字典树-Python

字典树 字典树又叫前缀树、单词查找树,树形结构,是哈希树的变种。能够统计、排序和保存大量的字符串,经常被搜索引擎系统用于文本词频统计。优点是利用字符串的公共前缀来减少查询时间,最大程度减少无谓字符串的比较,…

HBase入门:运行机制

文章目录 HBase 系统架构客户端ZooKeeper 服务器Master 主服务器Region 服务器 Region 服务器工作原理用户读写数据的过程缓存的刷新StoreFile合并 Store 的工作原理HLog 的工作原理 HBase 系统架构 HBase 的系统架构包括客户端、ZooKeeper 服务器、Master 主服务器、Region服…

什么是SQL,什么是MYSQL?MYSQL的架构以及SQL执行语句的过程是什么?有哪些数据库的类型?一篇文章带你弄懂!

文章目录 前言一、为什么需要数据库二、数据库的相关概念1.什么是结构化查询语言 (SQL)2.什么是数据库管理系统 (DBMS)3.什么是 MySQL 数据库 三、数据库分类1.关系型数据库(SQL)2.非关系型数据库(NoSQL) 四、MYSQL架构1.各组件功…

【大厂AI课学习笔记】1.2 现阶段人工智能方法和技术领域

目录 1.2 现阶段人工智能方法和技术领域 1.2.1 从技术应用场景展开 计算机视觉 语音识别 自然语言处理 1.2.2 实现AI的技术工具 机器学习的主要类型: 深度学习的重要性: 1.2 现阶段人工智能方法和技术领域 1.2.1 从技术应用场景展开 计算机视觉…

OpenCV-27 Canny边缘检测

一、概念 Canny边缘检测算法是John F.Canny与1986年开发出来的一个多级边缘检测算法,也被很多人认为是边缘检测的最优算法。最优边缘检测的三个主要评价标准是: 低错频率:表示出尽可能多的实际边缘,同时尽可能的减小噪声产生的误…

503 Service Temporarily Unavailable nginx 原因和解决办法

前言 HTTP 503 Service Temporarily Unavailable 错误通常表示服务器无法处理请求,可能是由于服务器过载、维护或其他临时性问题导致的。在 Nginx 中,这种错误通常与后端服务的可用性问题相关。以下是可能的原因和解决办法: 正文…

windows安装openResty

一、openResty安装 1、下载 进入openResty官网: OpenResty - 下载 下载下图中的64zip包 2、解压zip,进入目录 进入conf目录(openresty-1.25.3.1-win64\conf),找到nginx.conf文件,打开 3、修改配置文件&a…

ChatGPT AI革命-阅读心得

ChatGPT AI革命-阅读心得 一、揭秘ChatGPT二、OpenAI三剑客三、让ChatGPT飞起来四、ChatGPT的商业化落地五、ChatGPT编程六、AIGC与产业生态七、其他AIGC工具八、AIGC背后的伦理、法制和法律 本书围绕2022年11月OpenAI发布ChatGPT,ChatGPT在人工智能领域引起巨大轰动…

k8s学习-DaemonSet和Job

1.1DaemonSet是什么 Deployment部署的副本Pod会分布在各个Node上,每个Node都可能运行好几个副本。DaemonSet的不同之处在于:每个Node上最多只能运行⼀个副本。DaemonSet的典型应用场景有: (1)在集群的每个节点上运⾏存…

Redis 面试题 | 16.精选Redis高频面试题

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

【css揭秘】

文章目录 背景与边框半透明边框多重边框box-shadowoutline 背景定位background-positionbackground-origincalc() 条纹背景水平条纹 形状圆形圆柱自适应的椭圆半椭圆四分之一椭圆 背景与边框 半透明边框 目标:给一个容器设置一层白色背景和一道半透明白色边框 写…

Redis学习——入门篇③

Redis学习——入门篇③ 1. Redis事务1.1 事务实际操作1.2 watch 2. Redis管道(pipelining)2.1 管道简介2.2 管道实际操作2.3 管道小总结 3. Redis(pub、sub)发布订阅(不重要)3.1 简介3.2 发布订阅实际操作 这是一个分水岭…

1.【Vue3】前端开发引入、Vue 简介

1. 前端开发引入 1.1 前端开发前置知识 通过之前的学习,已经通过 SpringBoot 和一些三方技术完成了大事件项目的后端开发。接下来开始学习大事件项目的前端开发,前端部分借助两个框架实现: Vue3(一个 JS 框架)基于 …

go 引用fork后的模块的两种方式(replace和工作区)

很久没更新了,一是工作琐碎,二是处在舒适区,但最近看着身边的同事一个个离开,危机感骤然而生,不得不重拾书本,毕竟生活还得继续,不卷是不可能的,谁让我们生在这个卷中卷的国度&#…

MySQL主从同步数据库环境部署

本次部署的是MySQL主从环境的数据库信息 IP用途134.80.21.140Master134.80.21.141Slave 下面部署的详细配置 1.卸载系统自带的Mariadb [rootmysql-master ~]# rpm -qa |grep -i mariadb mariadb-libs-5.5.68-1.el7.x86_64 rpm -e mariadb-libs-5.5.68-1.el7.x86_64 --nodep…

指数计算(填空)

解题思路: 7的2020次方很大,需要用BigInteger来进行运算。 pow用来算指数运算。 remainder用来算BigInteger之间的取余。 解题代码: public static void main(String[] args) {BigInteger xnew BigInteger ("7");BigInteger ynew…

开源直播电商系统的实现方式(仿抖音电商模式)

当下,传统的图文电商模式正在走向没落,以“抖音”为首的直播电商模式备受用户追捧,它具有直观与互动的特点,拥有传统电商所不具备的优势。而且,当前正是直播电商的红利期,很多主播和品牌商都通过直播电商业…

阿里云上传文件

阿里云上传文件1&#xff08;未分模块&#xff09; 1、pom文件加入依赖 <!--阿里云 OSS 依赖--> <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.15.1</version> </d…

Bug: git stash恢复误drop的提交

Bug: git stash恢复误drop的提交 前几天在写ut时突然需要通过本地代码临时出一个包&#xff0c;但是本地ut又不想直接作为一个commit提交&#xff0c;所以为了省事就将ut的代码暂时stash起来。出完包后想apply stash&#xff0c;但是手误操作点成了drop stash&#xff0c;丢失了…