MySql中的锁

MySql中的锁

从锁的粒度分

  1. 行锁 :行锁粒度小,但加锁资源开销比较大,InnoDB支持
    从锁的排他性分
    1.1 共享锁读锁 ):多个事务可以对同一个数据共享一把锁,但是只能读不能修改。select XXX lock in share mode会加共享锁。普通的select是无锁的。在串行化级别下,普通select语句会自动加上共享锁。
    1.2 排他锁写锁):只有一个事务可以获得排他锁。InnoDB会对update/insert/delete语句自动加排他锁。select XXX for update 会加排他锁。
  2. 表锁 :表锁粒度大,但加锁资源开销比较小,MyISAM和InnoDB都支持
    从锁的排他性分
    2.1 共享锁读锁 ):同上
    2.2 排他锁写锁 :同上
    2.3 意向锁:InnoDB自动添加的锁。比如当向表中添加行锁时,InnoDB会在表上添加意向锁,此时如果需要加表排他锁就不需要逐条记录判断是否有锁,只需查看意向锁即可。
  3. 全局锁:加锁之后整个数据库实例都处于只读状态,所有数据变更操作都会被挂起,一般用于全库备份的时候。

从锁的算法分

  1. 记录锁:锁一条具体的数据。update XXX set XXX where id = XXX
  2. 间隙锁:锁住一个区间。RR级别下才会有间隙锁。为了防止幻读。update XXX set XXX where id > 10 and id <30范围更新会锁住间隙。 比如id字段有1,10,20三条记录。在RR级别下会分成(负无穷,1)(1,10)(10,20)(20,正无穷)这几个区间,update区间内不存在的记录,会锁住整个区间。
  3. 临键锁(Next-key):间隙锁+右记录锁。MySql在实际中会使用临建锁而不是间隙锁。即(负无穷,1](1,10](10,20](20,正无穷)

自增锁

针对MySql当中的自增字段。自增序列不可以回滚,因此会有不连续的情况。

相关推荐
AI_56785 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw5 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30735 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道5 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据7 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务7 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯8 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七8 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草8 小时前
redis-9-哨兵
数据库·redis·bootstrap
明哥说编程9 小时前
Dataverse自定义表查询优化:D365集成大数据量提速实战【索引配置】
数据库·查询优化·dataverse·dataverse自定义表·索引配置·d365集成·大数据量提速