【mysql学习笔记30】锁(非教程)

分类

  • 全局锁:锁住一个库
  • 表级锁:锁住一张表
  • 行级锁:锁住一行记录

全局锁

全局锁是对整个数据库进行加锁,锁住以后整个数据库将处于只读状态,其余操作均会阻塞。
应用场景就是一致性数据库备份时需要加全局锁,防止备份过程中数据变动。

使用全局锁

flush tables with read lock;

mysql备份命令

mysqldump -u root -p 1234 db_name>backup.sql

表级锁

分类
  • 表锁(又分为read lock和write lock)
  • 元数据锁(meta data lock,MDL)
  • 意向锁

元数据锁

简介
元数据锁是有mysql系统自行控制的,我们无需显示使用。元数据锁主要是用来维护元数据的数据一致性,在表上有活动事务的时候,不可以对元数据进行写入操作。
理解
元数据可以理解为一张表的结构信息,当一张表上有活动事务的时候,元数据锁会被自动加上,防止操作数据途中表结构被修改导致各种意外情况。
加锁时机
当对一张表进行增删改查的时候,加MDL读锁。
当对一张表结构进行变更操作的时候,加MDL写锁。

加表锁

lock tables 表名 read;
一旦加了读锁,所有连接包括自己都不能写,只能读
lock tables 表名 write;
一旦加了写锁,加锁的连接可以读和写,其它连接既不能读也不能写

解锁

unlock tables;

意向锁

介绍
通过加意向锁,另一个线程在加表锁的时候就不需要遍历所有行来判断是否能加锁,提高了效率。
分类
意向共享锁:由语句select … lock in share mode添加,与表锁共享锁兼容,与排他锁互斥
意向排他锁:由insert、update、delete、select … for update添加,与表锁共享锁以及排他锁都互斥

行级锁

介绍

行级锁,每次操作锁住对应行数据。锁定力度最小,发成锁冲突的概率最低,并发度最高。应用在InnoDB存储引擎中。
InnoDB的数据是基于索引组织的,行锁通过对索引上的索引项加锁来实现,而不是对记录加锁

分类
  • 行锁:锁定单个行记录,防止其它事务对此进行update和delete。
  • 间隙锁:锁定索引记录间隙(不包含该记录),确保索引记录间隙不变,防止其他事务在这个间隙进行insert,产生欢度。
  • 临键锁:是行锁和间隙锁的组合,相当于闭区间的间隙锁
行锁
  • 共享锁:允许其他事务读
  • 排他锁:禁止其他事务读写

在这里插入图片描述
ps:如果增删改的条件没有覆盖索引,那么Innodb会对所有记录加锁,就升级为了表锁

间隙锁/临键锁

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值