MySQL锁

select * from table where id =1 Lock in share Mode ; 加共享锁(id为主键索引,加的行锁) Lock in share Mode

select * from table where score =99 Lock in share Mode ;
加共享锁(加的表锁) Lock in share Mode
InnoDB若选择不带索引的列加锁会提升为表锁,此时整张表都不能进行修改操作
InnoDB 默认加的行锁

排他锁:加锁的数据不能被其他事物加锁查询及修改,普通查询是可以的

select * from table where id =1 for update; 排他锁 for update

mylsam 读锁 所有连接只能查询不能修改 lock table 表名 read ;

lock table student read ;

unlock tables; 解锁 只有解锁后才能修改

mylsam 写锁 lock table 表名 write;
其他连接不能查询或修改数据,本连接可以修改

lock table student write;

unlock tables; 解锁

=上面的锁都是悲观锁=

乐观锁的实现方式 加标记的思想
第一种在表中新增一个字段 version
每次修改 前先查询当前版本号
select version from city where name=“广州”
修改操作 版本号+1,并对比版本号是否相同
update city set name=“广州市”,version=version+1 where name =“广州” and version=(select version from city where name=“广州” )

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值