数据库的隔离级别

隔离级别及含义

事务隔离级别(transaction isolation levels):

隔离级别就是对对事务并发控制的等级。
ANSI/ ISO SQL将其分为:
串行化(SERIALIZABLE)、
可重复读(REPEATABLE READ)、
读已提交(READ COMMITED)、
读未提交(READ UNCOMMITED)四个等级。为了实现隔离级别通常数据库采用锁(Lock)。一般在编程的时候只需要设置隔离等级,至于具体采用什么锁则由数据库来设置。

串行化(SERIALIZABLE):所有事务都一个接一个地串行执行,这样可以避免幻读(phantom reads)。对于基于锁来实现并发控制的数据库来说,串行化要求在执行范围查询(如选取年龄在10到30之间的用户)的时候,需要获取范围锁(range lock)。如果不是基于锁实现并发控制的数据库,则检查到有违反串行操作的事务时,需要滚回该事务。

可重复读(REPEATABLE READ):所有被Select获取的数据都不能被修改,这样就可以避免一个事务前后读取数据不一致的情况。但是却没有办法控制幻读,因为这个时候其他事务不能更改所选的数据,但是可以增加数据,因为前一个事务没有范围锁。

读已提交(READ COMMITED):被读取的数据可以被其他事务修改。这样就可能导致不可重复读。也就是说,事务的读取数据的时候获取读锁,但是读完之后立即释放(不需要等到事务结束),而写锁则是事务提交之后才释放。释放读锁之后,就可能被其他事物修改数据。该等级也是SQL Server默认的隔离等级。
读未提交(READ UNCOMMITED):这是最低的隔离等级,允许其他事务看到没有提交的数据。这种等级会导致脏读(Dirty Read)。

事务并发可能出现的问题:

脏读:
事务T1将某一值修改,事务T2在T1修改后读取了该值,之后由于某种原因,T1撤销了对该值的修改,则T2读取的是无效的数据。

不可重复读:
是指在数据库访问中,一个事务范围内两个相同的查询却返回了不同的数据。这是由于查询时系统中其他事务修改的提交引起的,比如事务T1读取某一数据,事务T2读取并修改了该数据,T1为了对读取值进行检验而再次读取该数据,便得到了不同的结果。

幻读:
幻读是指当事务不是同时执行时发生的现象,比如,事务T1对一个表中的数据进行了修改,比如这种修改涉及到表中的“所有数据行”,同时,事务T2也修改这个表中的数据,这种修改是向表中“添加一行新数据”。T1会发现表中还存在没有修改的数据,就好像产生了幻觉一样。
<以上内容来自摘自百科>
------------------------以上内容有待修改-----------------------------

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值