数据库的事务隔离级别

数据库隔离级别:

是在数据库操作中,为了有效保证并发读取数据的正确性提出的。

隔离级别越高,越能保证数据的完整性和一致性,但是对并发性的影响也越大。对于大多数应用程序,都采取 READ COMMITTED的隔离等级。它能够避免脏读取,并且并发性性能较好。尽管它会导致,不可重复读、幻读、第二类丢失更新的问题,但是可以通过悲观锁和乐观锁进行控制。

数据库的几种事务隔离级别:

READ UNCOMMITTED :(读未提交数据)允许事务读取其他事务未提交的变更数据,会出现脏读、幻读、不可重复读的问题。

READ COMMITTED:(读已提交数据)只允许事务读取其他事务已经提交的变更数据,可避免脏读,但是还是会出现不可重复读和幻读问题。

REPEATABLE READ:(可重复读)确保事务可以多次从一个字段中读取相同的值,在此事务期间其他事务无法对该字段进行更新,可以避免脏读和不可重复读,但是仍然会出现幻读问题。

SERIALIZABLE:(序列化)确保事务可以从一个表中读取相同的行,在此事务持续期间,禁止其他事务对该表执行插入、更新和删除操作,可避免所有并发问题,但性能非常低。

Oracle支持两种事务隔离级别:

  READ COMMITTED(默认事务隔离级别),SERIALIZABLE

MySQL支持四种事务隔离级别,其中REPEATABLE READ为默认事务隔离级别。

通过上面可以知道多事务同时运行,如果不采用以上四种隔离机制,可能会产生多个并发问题,其中包括脏读、不可重复读和幻读,下面就解释下这几种并发问题:

存在两个事务(T1,T2)同时运行。

脏读:T1已经读取了T2已经修改但是尚未提交的数据,,由于某种原因T2数据回滚。则T1读取的数据是临时并且无效的。

不可重复读:T1读取一个字段,之后T2对这个字段进行了更新,T1再次读取改字段值发生了变化。

幻读:T1读取了一个表的一个字段,然后T2在该表中插入了一些新的行,之后T1读取此表会多出几行。

数据库事务的特性:

原子性:事务的原子性指的是,事务中包含的程序作为数据库的逻辑工作单位,它所做的对数据修改操作要么全部执行,要么完全不执行,这种特性称为原子性。(简单地说就是,几个对于数据库的操作要么全执行,要么全不执行,即同时成功起作用或同时失败没影响)。

一致性:事务一致性值得是在一个事务执行之前和执行之后数据库都必须处于一致性状态(中途是否一致不用管),这种特性称为一致性。(如果数据库的状态满足所有的完整性约束,就说该数据库是一致的。一致性处理数据库中对所有语义的保护。如:客户K1要向客户K2转账,K1账户减少的金额就是K2账户增加的金额,在转账之前K1和K2账户的金额之和与转账之后K1和K2账户的金额之和是一样的,在转账期间可能不满足这种一致性,但事务前后是数据库数据是一致的)。

隔离性:隔离性指的是并发的事务是相互隔离的。(一个事务内部的操作及正在操作的数据必须封装起来,不被其它企图进行修改的事务看到);

持久性:持久性指当系统或介质发生故障时,确保已提交的更新不能丢失。(一个事务提交,DBMS保证它对数据库中数据的改变应该是永久性的,可以经受任何系统故障,持久性通过数据库备份和恢复来保证)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值