事务的四大特性,隔离级别的作用?

事务的四大特性,隔离级别的作用?
事务(Transaction):是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合(工作逻辑单元);

四大特性:

原子性(atomicity):事务是一个完整的操作。事务的各步操作是不可分的;要么都执行、要么都不执行。

一致性(consistency):当事务完成时,数据必须处于一致状态。

隔离性(isolation):对数据进行修改的所有并发事务是彼此隔离的,这表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务。

 持久性(durability):事务完成后,它对数据库的修改被永久保存,事务日志能保持事务的永久性。

隔离级别分为:

读未提交(Read Uncommitted):允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个数据则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。

读已提交(Read Committed):允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。

可重复读取(Repeatable Read):禁止不可重复读取和脏读取,但是有时可能出现幻影数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。

序列化(Serializable):提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,但不能并发执行。如果仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。

在这里插入图片描述

脏读:一个事务读取的另一个事务未提交的数据。
不可重复读:一个事务读取到另一个事务已提交的数据,单条记录前后不匹配。
幻读(虚读):一个事务读取到另一个事务已提交的数据,多读到几条记录。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值