MySql的事务隔离级别

前言

数据库都是有事务的,事务的不同级别,对应数据操作的不同级别安全性。本文以MySql为例介绍一下数据库的事务隔离级别。

 

事务定义

事务是将数据从一种状态改变到另一种状态。

事务隔离级别是事务看别的事务修改的数据的可见程度。

 

事务的可见性

脏读 (Dirty read): 一个事务读取到另一个事务还没有提交的数据,又叫无效数据读取。

Example: 事务一对数据进行了增删改等写操作,但还未提交,事务二可以读取到事务一还未提交的数据。这时候事务一Rollback了,事务二读到的就是脏数据。

 

不可重复读 (Non-repeatable read):在同一个事务内的两次相同的查询,返回不同的数据。

Example: 在同一事务内的第一次读操作和第二次读操作之间,另外一个事务对数据进行了修改,这时候两次读取的数据是不一致的。

不可重复读的重点是修改。同样的条件,两次读取出来的数据不一样。

 

幻读 (Phantom read):两个对数据进行修改的事务,一个修改,一个新增或删除。

Example: 事务一对一定范围的数据进行批量修改,事务二在这个范围增加或删除了一条数据,这时候第一个事务就会丢失对新增数据的修改。事务一认为出现了幻想。

幻读的重点在于新增或删除。

 

幻想读是可重复读,区别是 :已读取的数据是不变的,只是看到了更多的数据。

 

事务的隔离级别

隔离级别隔离级别的值导致的问题
Read-Uncommitted0导致脏读
Read-Committed1避免脏读,允许不可重复读和幻读
Repeatable-Read2避免脏读和不可重复读,允许幻读
Serializable3串行化读,事务只能一个一个执行,避免了脏读、不可重复读、幻读。执行效率慢,使用时慎重

 MySql的默认隔离级别是可重复读。

 

Summary:

隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。

大多数的数据库默认隔离级别为 Read Commited,比如 SqlServer、Oracle、Postgresql。

少数数据库默认隔离级别为:Repeatable Read 比如: MySQL InnoDB。

 

Tips:

综合而言,因为使用数据库事务隔离级别的成本消耗太大,一般在应用层做事务控制,比如使用乐观锁、分布式事务,来消除在数据库层使用事务的压力。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值