mysql 锁

在这里插入图片描述1.表锁(便读)

表锁偏向于MYSAIM 存储引擎,开销小,加锁块 无思索,锁的颗粒度大,发生锁冲突的概率高,并发最低

手动增加表锁
lock table 表名称 read(write) ,表名称2read(write)

查看表加过的锁
show open tables;

删除表锁
unlock tables;

总结
读锁加上之后只能读 ,其他session 可以读 ,但是session 写入会报错;一般用来做表数据迁移;
写锁加上之后本 session 可以curd ,但是其他session curd 一个都不能执行(排他锁)
在这里插入图片描述

2.行锁
session_1 跟新某一行使用行锁,其他session 无法操作这行,但是操作其他行可以;
开始事物(begin)的时候 就加上,commit 就释放;
逛街在这里插入图片描述在这里插入图片描述
总结:
(1).使用可重复读的隔离级别 会使用mvcc机制.select 操作不会更新版本号,是快照读(历史版本);insert update 和delete 会更新版本号,是当前读(当前版本)

要是想避免幻读 又不想使用可串行话隔离级别(影响并发) ,可以使用锁, 比如间隙锁:
当前id 最大值是6 update tabele set a =1 where id> 5 and id<=10 , 虽然 7-10不存在,但是都会加锁,导致其他线程无法新增数据;或者 select * from table for update;

在这里插入图片描述在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值