事务与数据库隔离级别

什么是事务

事务由一组操作构成,我们希望这组操作能够全部正确执行,如果这一组操作中的任意一个步骤发生错误,那么就需要回滚之前已经完成的操作。也就是同一个事务中的所有操作,要么全都正确执行,要么全都不要执行。
 

事务四大特性ACID

原子性(Atomicity)

事务是一个不可分割的执行单元,事务中的所有操作要么全都执行,要么全都不执行。

一致性(Consistency)

一致性要求,事务在开始前和结束后,数据库的完整性约束没有被破坏。

隔离性(Isolation)

事务的执行是相互独立的,它们不会相互干扰,一个事务不会看到另一个正在运行过程中的事务的数据。

持久性(Durability)

一个事务完成之后,事务的执行结果必须是持久化保存的。即使数据库发生崩溃,在数据库恢复后事务提交的结果仍然不会丢失。
 

事务并发执行会出现的问题

1. 脏读

一个事务读到另一个尚未提交的事务中的数据。该数据可能会被回滚从而失效。 如果第一个事务拿着失效的数据去处理那就发生错误了。

2. 不可重复读(虚读)

一个事务对同一行数据读了两次,却得到了不同的结果。
如:在一个事务内,多次读同一个数据。在这个事务还没有结束时,另一个事务也访问该同一数据。那么,在第一个事务的两次读数据之间。由于第二个事务的修改,那么第一个事务读到的数据可能不一样,这样就发生了在一个事务内 两次读到的数据是不一样的,因此称为不可重复读,即原始读取不可重复。

3. 幻读

指一个线程中的事务发现了另外一个线程中提交的insert或delete的数据。
事务1在两次查询之间,事务2对该表进行了插入、删除操作,导致事务1发现还有没有修改或缺失了数据,似乎发生幻觉一样。(简单来说,幻读是由插入或者删除引起的)

不可重复读 与 脏读 的区别?

脏读读到的是尚未提交的数据,而不可重复读读到的是已经提交的数据,只不过在两次读的过程中数据被另一个事务改过了。

 

数据库的四种隔离级别

对应以上事务隔离引发的问题,需要设置事务隔离级别

1. Read uncommitted 读未提交

在该级别下,一个事务对一行数据修改的过程中,不允许另一个事务对该行数据进行修改,但允许另一个事务对该行数据读。 因此本级别下,不会出现更新丢失,但会出现脏读、不可重复读、幻读。

2. Read committed 读提交

在该级别下,未提交的写事务不允许其他事务访问该行,因此不会出现脏读;
读取数据的事务允许其他事务的访问该行数据,因此会出现不可重复读和幻读。

3. Repeatable read 重复读

在该级别下,读事务禁止写事务,但允许读事务,因此不会出现同一事务两次读到不同的数据的情况(不可重复读),且写事务禁止其他一切事务。会出现幻读。

4. Serializable 序列化

该级别要求所有事务都必须串行执行,因此能避免一切因并发引起的问题,但效率很低。

内容来源:
 
分布式事务入门指南 · 常用分布式事务解决方案
面试官:谈谈Mysql事务隔离级别?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值