位置: 编程技术 - 正文

关于MySQL innodb_autoinc_lock_mode介绍(关于植物的现代诗)

编辑:rootadmin

推荐整理分享关于MySQL innodb_autoinc_lock_mode介绍(关于植物的现代诗),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:关于中秋节的古诗,关于我和鬼变成家人的那件事,关于翡翠手镯知识,关于中秋节的古诗,关于Mysql Innodb行记录隐藏字段的说法正确的是,关于我和鬼变成家人的那件事,关于我和鬼变成家人的那件事,关于Mysql Innodb行记录隐藏字段的说法正确的是,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

【0】我们先对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');

【1】innodb_autoinc_lock_mode 的说明

innodb_auto_lockmode有三个取值:

1、0 这个表示tradition 传统

2、1 这个表示consecutive 连续

3、2 这个表示interleaved 交错

【1.1】tradition(innodb_autoinc_lock_mode=0) 模式:

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

2、在这一模式下,所有的insert语句("insert like") 都要在语句开始的时候得到一个表级的auto_inc锁,在语句结束的时候才释放这把锁,注意呀,这里说的是语句级而不是事务级的,一个事务可能包涵有一个或多个语句。

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

关于MySQL innodb_autoinc_lock_mode介绍(关于植物的现代诗)

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

【1.2】consecutive(innodb_autoinc_lock_mode=1) 模式:

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

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

【1.3】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 的例子来结束

例子:不要没事去更新一个auto_increment 列的值

第一步:重现一下场景

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

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

第四步:对问题的总结

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

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

以上这篇关于MySQL innodb_autoinc_lock_mode介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

mysql巡检脚本(必看篇) 如下所示:#!/usr/bin/envpython3.5importpsutilimportmysql.connectorimportargparseimportjsonimportdatetimedefget_cpu_info(verbose):cpu_info={}ifverbose0:print("[cpu]startcollectcpuinfo...")data=psu

MySQL-group-replication 配置步骤(推荐) MySQL-Group-Replication是mysql-5.7.版本开发出来的新特性;它在master-slave之间实现了强一致性,但是就目前来说主要是性能不太好。【1】确定当前的mysql数据

innodb引擎redo文件维护方法 如果要对innodb的redo日志文件的大小与个数进行调整可以采用如下步骤:1、关闭mysqlmysqladmin-h.0.0.1-P-uroot-pshutdown2、修改配置文件中的innodb_log_file_size

标签: 关于植物的现代诗

本文链接地址:https://www.jiuchutong.com/biancheng/349944.html 转载请保留说明!

上一篇:关于mysql create routine 权限的一些说明(关于月亮的诗句)

下一篇:mysql巡检脚本(必看篇)(mysql数据库巡检脚本)

  • 营改增抵减的销项税额会计分录
  • 税务行政复议包括必须复议自由复议和选择复议三种类型
  • 购入原材料计划成本
  • 应交税费转出未交增值税借贷方表示什么
  • 小规模纳税人普票收入会计分录
  • 国内旅客运输服务电子普通发票
  • 房地产企业分立会计处理及税务筹划案例解析
  • 购进环保节能设备如何抵扣进项税
  • 信用卡产生滞纳金
  • 建筑业农民工工资
  • 收到销项负数发票怎么处理
  • 2020深圳增值税税率是多少
  • 股利分配政策的研究背景
  • 月末印花税会计分录
  • 单位缴交的社保和医保还要交其他费用吗
  • 递延所得税收益计算公式
  • 销售不动产增值税计税依据
  • 怎么看是不是专用发票
  • 工资计提不发放工资个税
  • 对方公司已注销,我公司应付款怎样支付
  • 社保企业报盘是什么
  • 间接生产费用包括
  • 不良品退回处理流程
  • u盘如何进行杀毒
  • 进项税和销项税怎么理解
  • 购买监控设备费用谁出
  • 成本核算的意义是什么
  • php正则替换字符串
  • 消费税有减免政策吗
  • 鸿蒙系统蓝牙耳机声音小怎么办
  • 共管账户的定义
  • 公益性捐赠支出的标准
  • 个人所得税的减数为2000元,实行日期为
  • 安格雷尔
  • 图像风格迁移网站
  • php如何实现
  • 现代服务印花税税率
  • 房地产企业预缴增值税会计处理
  • 银行查询余额
  • 企业哪些支出可以用现金支付
  • 年金终值系数是指已知( ),求终值
  • 个体升一般纳税人的界限
  • 企业哪些增值税免征
  • 营改增后企业的税负控制
  • 设备维修会计分录如何写
  • 企业稳岗返还使用情况明细表
  • 在建工程待摊支出结转
  • 私人账户可以打钱到公司账户吗
  • 原材料 半成品
  • 固定资产报废会议纪要模板
  • 企业设备维修
  • 员工借款怎么处理
  • 销售费用和管理费用的税前扣除
  • 科目汇总表账务处理程序登记总账的依据是
  • 企业试生产时间规定
  • linux大型软件
  • 使用u盘安装windows10电脑识别不出来
  • 神舟hasee笔记本测评
  • macappstore下载软件一直要密码
  • shell下同时读取多个文件的方法
  • win7系统耳机设置在哪里
  • ms-dos 6.2批处理文件高级指南
  • cocos2d教程
  • cocos2dx4.0入门
  • js定义数字
  • 用python抓取数据
  • js必须掌握的知识点
  • unity3d碰撞体
  • vue插件使用
  • android fragmentactivity
  • js的类型有哪几种
  • 友盟模块
  • jquery propertychange
  • jquery是怎样实现链式调用的?
  • python搭建平台
  • 云南省税务局app缴费
  • 国家税务总局公告2023第12号
  • 掌上海关怎么查询
  • 辽宁网上税务
  • 食品烟酒消费包括哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设