MySQL(InnoDB剖析):---锁之(自增长与锁、外键和锁)

一、自增长与锁

  • 自增长在数据库中是非常常见的一种属性,也是开发人员首选的主键方式

自增长计数器

  • 在InnoDB的内存结构中,对每个含有自增长值的表都有一个自增长计数器auto-increment counter),当对含有自增长的计数器的表进行插入操作时,这个计数器会被初始化
  • 执行如下的语句可以得到计数器的值
select max(auto_inc_col) from t for update;

自增长与锁(AUTO-INC Locking)

  • 插入操作会依据这个自增长的计数器值加1赋值给自增长列。这个实现方式称作AUTO-INC Locking
  • 这种锁其实是采用一种特殊的表锁机制,为了提高插入的性能,锁不是在一个事务完成后才释放,而是在完成对自增长值插入的SQL语句后立即释放
  • 虽然AUTO-INC Locking从一定程度上提高了并发插入的效率,但是还存在一些性能上的问题
    • 首先,对于有自增长值的列的并发插入性能较差,事务必须等待前一个插入的完成(虽然不用等待事务的完成)
    • 其次,对于INSERT...SELECT的大数据量的插入会影响插入的性能因为另一个事务中的插入会被阻塞

innodb_autoinc_lock_mode参数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值