事务
- 事务的四大特性 ( ACID )
- 脏读
- 不可重复读
- 幻读
- MySQL的隔离级别
事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败,
事务的四大特性 ( ACID )
原子性(Atomicity):一个事物是一个不可分割的单位,要么全都执行,要么都不执行;
一致性(Consistency):事务执行前后,资料处于合法的状态;
持久性(Isolation):事务执行完后,资料的修改是持久的,不会因为其他操作或故障而对其产生影响;
隔离性(Durability):多个事务并发执行的,事务之间不互相干扰,
假如事物的一个操作整体(动作A,B),动作A,执行完了,动作B,执行到一半,执行程序出错,这时怎么办?有回滚机制,有个日志会记录这些操作,记录资料修改前和资料修改后的值,
脏读
事务A正在修改资料(但是没有提交),事务B就读取了这里的资料,此时事务B读取的操作称为脏读,
解决办法:给写操作加锁,当事务A在写资料的时候,事务B无法读取,
不可重复读
事务A修改资料之后提交了资料“name=L”,然后事务B就读取资料,但是此时A觉得修改的资料不满意“name=H”,继续修改提交了,此时事务B再次读取,发现,啊,怎么资料不一样了,这就是不可重复读的问题,
解决办法:给写操作加锁的同时,给读操作也加锁,当事务A在写的时候,事务B不可以读,事物B在读的时候,事物A也不可以写,
幻读
虽然已经给写操作加锁,和读操作加锁,但是会有种情况,事务B在读的时候,事务A无法修改name,但是事务A可以再写一个age,当事务B再次读取资料的时候发现,咦,怎么多了条资料,
解决办法:只能严格的串行化执行,(并发程度最低,效率也最低,但是资料的可靠性最高)
这里很容易搞混不可重复读和幻读,其实只需要理解,不可重复读是修改资料,资料的条数不变;幻读是增加或者洗掉资料,资料的内容不变,条数发生改变,
MySQL的隔离级别
读未提交(read-uncommitted):会有脏读,不可重复读,幻读问题
不可重复读(read-committed):会有不可重复读,幻读问题
可重复读(repeatable-read):会有幻读问题
串行化 (serializable):解决这三个问题
事务的隔离级别并不是越高越好,但事务的隔离级别越高,那么并发性就越低,效率越低,资料的可靠性就会越高,
MySQL8开始,用SELECT@@GLOBAL.transaction_isolation,@@transaction_isolation;
查询隔离级别(这里是是MySQL5)
这里我们可以看到MySQL的全域隔离级别和当前会话隔离级别皆是REPEATABLE一READ(可重复读),不同的数据库有不同的默认隔离级别,而且我们也可以自行修改它,
通过如下命令可以修改隔离级别(建议在修改时修改当前 session 隔离级别即可,不用修改全域的隔离级别):
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
注意,如果只是修改了当前 session 的隔离级别,则换一个 session 之后,隔离级别又会恢复到默认的隔离级别,所以我们测验时,修改当前 session 的隔离级别即可,
0 评论