mysql隔离级别、锁机制

隔离级别

1、Read Uncommitted
可能出现问题举例:读脏

2、Read Committed
可能出现问题举例:不一致

3、Repeatable Read
可能出现问题举例:幻读

4、Serializable
可能出现问题举例:超时

锁机制

这里写图片描述
1、开启两个会话
2、每个会话开启事务
3、第一个会话中执行update sql(返回结果)
4、第二个会话中执行update sql(等待返回)
5、第一个会话提交事务(第二个会话返回结果)
6、第二个会话提交事务

对比以下几组sql(存在索引和普通列的区别)

a、
select num from test where id = 1 for update;
select num from test where id = 1 for update;
b、
select num from test where id = 1 for update;
select num from test where id = 2 for update;
c、
select num from test where num = 1 for update;
select num from test where num = 1 for update;
d、
select num from test where num = 1 for update;
select num from test where num = 2 for update;

死锁

会话1:
    1、START TRANSACTION;

    3、SELECT num FROM test1 WHERE id = 1 FOR UPDATE;

    5、SELECT num FROM test2 WHERE id=1 FOR UPDATE;

    7、COMMIT;
会话2:
    2、START TRANSACTION;

    4、SELECT num FROM test2 WHERE id = 1 FOR UPDATE;

    6、SELECT num FROM test1 WHERE id=1 FOR UPDATE;

    8、COMMIT;

间隙锁:

会话1:
    1、START TRANSACTION;

    3、SELECT num FROM test WHERE id > 1 AND id < 5 FOR UPDATE;

    5、COMMIT;
会话2:
    2、START TRANSACTION;

    4、INSERT INTO test(id,num) VALUES(3,3);

    6、COMMIT;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值