innodb_autoinc_lock_mode这个参数控制着在向有auto_increment 列的表插入数据时,相关锁的行为;

通过对它的设置可以达到性能与安全(主从的数据一致性)的平衡

我们先对insert做一下分类

首先insert大致上可以分成三类:

1、simple insert 如insert into t(name) values('test')

2、bulk insert 如load data | insert into ... select .... from ....

3、mixed insert 如insert into t(id,name) values(1,'a'),(null,'b'),(5,'c');

innodb_autoinc_lock_mode 的说明

innodb_auto_lockmode有三个取值:

1、0 这个表示tradition 传统

2、1 这个表示consecutive 连续

3、2 这个表示interleaved 交错

tradition(innodb_autoinc_lock_mode=0 模式:

1、它提供了一个向后兼容的能力

2、在这一模式下,所有的insert语句("insert like") 都要在语句开始的时候得到一个

表级的auto_inc锁,在语句结束的时候才释放这把锁,注意呀,这里说的是语句级而不是事务级的,

一个事务可能包涵有一个或多个语句。

3、它能保证值分配的可预见性,与连续性,可重复性,这个也就保证了insert语句在复制到slave 的时候还能生成和master那边一样的值(它保证了基于语句复制的安全)。

4、由于在这种模式下auto_inc锁一直要保持到语句的结束,所以这个就影响到了并发的插入。

consecutive(innodb_autoinc_lock_mode=1  模式:

1、这一模式下去simple insert 做了优化,由于simple insert一次性插入值的个数可以立马得到确定,所以mysql可以一次生成几个连续的值,用于这个insert语句;总的来说这个对复制也是安全的(它保证了基于语句复制的安全)

2、这一模式也是mysql的默认模式,这个模式的好处是auto_inc锁不要一直保持到语句的结束,只要语句得到了相应的值后就可以提前释放锁

interleaved(innodb_autoinc_lock_mode=2  模式:

1、由于这个模式下已经没有了auto_inc锁,所以这个模式下的性能是最好的;但是它也有一个问题,就是对于同一个语句来说它所得到的auto_incremant值可能不是连续的。

2、如果你的二进制文件格式是mixed | row 那么这三个值中的任何一个对于你来说都是复制安全的。

由于现在mysql已经推荐把二进制的格式设置成row,所以在binlog_format不 statement的情况下最好是innodb_autoinc_lock_mode=2 这样可能知道更好的性能。

关于auto_increment 的例子

第一步:重现一下场景

create table t(x int auto_increment not null primary key);insert into t(x) values(0),(null),(3);select * from t;+---+| x |+---+| 1 || 2 || 3 |+---+

第二步:重现一下引发问题的SQL

update t set x=4 where x=1;select * from t;+---+| x |+---+| 2 || 3 || 4 |+---+

第三步:重现一下总是的表现形式

(如果向一个自增键插入0或null,mysql将会使用自增值)

insert into t(x) values(0);ERROR 1062 (23000): Duplicate entry '4' for key 'PRIMARY'

第四步:对问题的总结

执行完第一步的时候mysql知道下一个auto_increment值是4。

执行完第二步的时候mysql并不知道4已经被人为的占用了,所以执行第三步的时候就错了。

注:

不要没事去更新一个auto_increment 列的值,除非在更新后重置Auto_increment值

(Alter Table TableName Auto_increment = 1##这里虽然是1,但它会以自增列的最大值为准)

mysql auto_inc_MySQL innodb_autoinc_lock_mode 详解相关推荐

  1. Mysql加锁过程详解(3)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  2. mysql status改变_mysql 配置详解mysql SHOW STATUS 详解

    1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很短)检查连接并且启动一个新线程. back_log ...

  3. MySQL 表分区详解MyiSam引擎和InnoDb 区别(实测)

    MySQL 表分区详解MyiSam引擎和InnoDb 区别(实测) 一.什么是表分区 通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了. 如:某用户表的记录超过 ...

  4. Mysql存储引擎详解(MyISAM与InnoDB的区别)

    Mysql存储引擎详解(MyISAM与InnoDB的区别) 存储引擎     MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平 ...

  5. MySQL的Limit详解(转载)

    MySQL的Limit详解 问题:数据库查询语句,如何只返回一部分数据? Top子句 TOP 子句用于规定要返回的记录的数目.对于拥有数千条记录的大型表来说,TOP 子句是非常有用的. 在SQL Se ...

  6. Mysql加锁过程详解(2)-关于mysql 幻读理解

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  7. 数据库mysql_row_MYSQL数据库mysql found_row()使用详解

    <MYSQL数据库mysql found_row()使用详解>要点: 本文介绍了MYSQL数据库mysql found_row()使用详解,希望对您有用.如果有疑问,可以联系我们. mys ...

  8. mysql 联合索引详解

    mysql 联合索引详解 联合索引又叫复合索引.对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分.例如索引是key index (a,b,c). ...

  9. MYSQL performance schema详解

    MYSQL performance schema详解 0.performance_schema的介绍 ​ MySQL的performance schema 用于监控MySQL server在一个较低级 ...

最新文章

  1. idea_pyspark 环境配置
  2. 阿里云rds linux平台使用wget 工具下载备份与日志文件
  3. 广义hough变换matlab,matlab – 广义Hough R表
  4. UA MATH567 高维统计IV Lipschitz组合11 社区发现 Spectral Clustering容许的最大随机噪声
  5. C# WPF MVVM开发框架Caliburn.Micro IResult和协同程序⑥
  6. TOMCAT启动汉字乱码解决方案
  7. eclipse远程连接hadoop_Hadoop群启集群
  8. 安卓fragment笔记
  9. mysql 索引 hash_Mysql中索引类型,B-tree、Hash索引怎么实现的以及其特点?
  10. ERP技术在财务信息化转型中应用探讨
  11. linux下运行二进制文件
  12. 游戏王决斗连接显示服务器错误,游戏王决斗链接
  13. win10计算机加域步骤,关于win10加入域的的详细操作步骤
  14. 来势汹汹 两大版本 百公里加速最快小于3.5s 电动车最大黑马居然是TA!
  15. SWAT 建模与案例应用
  16. 【Leetcode】[190] 颠倒二进制位
  17. 微信公众号排版的使用
  18. 日本旅馆业、民宿分类及管理规定
  19. 无胁科技-TVD每日漏洞情报-2022-11-16
  20. 百家号写的文章不给推荐怎么办?百家号怎么写出爆文?

热门文章

  1. 使用大数据分析需要注意什么因素
  2. 统计某一范围内所有的是K的倍数或者含有K的整数
  3. 安徽省学考计算机操作,安徽省教育考试院全国计算机等级考试网上报名流程与操作步骤...
  4. [ Typescript 手册] JavaScript `Date` 在 Typescript 中的接口
  5. c语言中注释参与程序设计的编译吗,C语言程序设计(第4章函数)6
  6. android组件的下拉回弹,转:Android可以下拉/上拉回弹的ListView原理
  7. 如何学习Python进行数据分析
  8. c语言txt操作,C语言文件操作总结
  9. NLP+语义分析(四)︱中文语义分析研究现状(CIPS2016、角色标注、篇章分析)
  10. 笔记︱信用风险模型(申请评分、行为评分)与数据准备(违约期限、WOE转化)