数据库事务的特性和隔离级别

数据库中的事务包含四个特性:
1.原子性

指事务包含的所有操作要么成功,要么全部失败回滚。

2.一致性

一致性是指事务执行前后是从一个一致性状态变为另一个一致性状态。比如转账事务前后两个账户中金额相加应该是一致的。

3.隔离性

隔离性是指多个用户访问数据库时候,数据库会为每个用户开启相应的事务,每个用户的操作不受其他用户所影响,即使多个并发的事务也是互相隔离。

4.持久性

持久性是指事务一旦提交,数据库中的数据就是永久性的改变,数据库发生异常也不会丢失已经回滚已经提交了的数据。

在操作数据库时,根据操作情况来划分,有以下情况:
1.脏读:

指读取了事务未提交的数据,如事务T1更新了一行记录,还未提交所做的修改,这个T2读取了更新后的数据,然后T1执行回滚操作,取消刚才的修改,所以T2所读取的行就无效,就是脏数据。

2.不可重复读:

指第一次读取的数据和第二次读取的数据有可能不一样,因为在第一次读取期间有可能有别的进行对数据进行了更新,针对的是Update语句。事务T1读取一行记录,紧接着事务T2修改了T1刚刚读取的记录,然后T1再次查询,发现与第一次读取的记录不同,这称为不可重复读。

3.幻读:

指第一次读取的数据个数和第二次读取的数据个数可能不一致,因为第一次读取期间可能发生了数据的删除或插入操作,针对Insert和Delete语句。事务T1读取一条指定where条件的语句,返回结果集。此时事务T2插入一行新记录,恰好满足T1的where条件。然后T1使用相同的条件再次查询,结果集中可以看到T2插入的记录,这条新纪录就是幻读的。

三者对比,脏读是读取了还未提交的数据,而不可重复读和幻读都是读取已经提交的事务,不可重复读是针对的同一个数据项的,幻读是针对数据这个整体的(包含数据的个数),所以可以说不可重复读是针对数据更新,幻读是针对数据的插入来说的。

针对以上这些情况,常用的数据库分出了四种隔离级别:
1. 串行化(Serializable):

最严格的一种,既可以避免脏读,又可以避免不可重复读和幻读,但是性能差

2. 可重复读(Repeatable Read):

可以避免脏读和不可重复读,不可避免幻读

3. 提交读(Read commited):

可以避免脏读,不可避免幻读和不可重复读

4. 未提交读(Read Uncommited):

可以读取未提交的事务,造成脏读,幻读,不可重复读

Mysql的默认事务隔离级别为可重复读(Repeatable read)
Oracle支持Read Commited和 Serializable,默认为提交读(Read Commited)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个开源的、适用于创建微服务的Java应用程序框架。它提供了简化的配置和开发过程,其中包括对事务处理的支持。Spring Boot的事务管理有以下四大特性隔离级别: 1. 原子性(Atomicity):事务是原子操作的基本单位,要么全部完成,要么全部回滚。在Spring Boot中,通过将需要进行事务管理的方法标记为@Transactional来实现原子性。 2. 一致性(Consistency):事务执行前后,数据库数据始终保持一致性状态。如果事务执行失败,数据将会被回滚到事务开始之前的状态。 3. 隔离性(Isolation):事务之间相互隔离,一个事务的执行不应该对其他事务产生影响。在Spring Boot中,可以通过设置隔离级别来控制事务隔离程度。常见的隔离级别包括读未提交、读已提交、可重复读和串行化。 4. 持久性(Durability):事务一旦提交,其结果将持久保存到数据库中,并且不会受到后续的故障或系统恢复的影响。 隔离级别决定了事务之间的相互影响程度,以及事务可能遭遇的并发问题。在Spring Boot中,可以通过设置隔离级别来控制事务的行为。读未提交的隔离级别是最低级别的隔离,它允许多个事务之间相互读取未提交的数据;读已提交的隔离级别要求一个事务只能读取已经提交的数据;可重复读的隔离级别保证在同一事务内的多次读取操作得到的结果是一致的;而串行化的隔离级别则是最高级别的隔离,它要求事务之间完全串行执行,避免了并发问题,但可能降低了并发性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值