事务

事务的ACID是指什么?https://blog.csdn.net/weixin_38070406/article/details/78157603

答:

- 原子性(Atomic):事务中各项操作,要么全做要么全不做,任何一项操作的失败都会导致整个事务的失败.

- 一致性(Consistent):事务的执行的前后数据的完整性保持一致. 

- 隔离性(Isolated):一个事务执行的过程中,不应该受到其他事务的干扰.

- 持久性(Durable):事务一旦结束,数据就持久到数据库.

隔离级别是指若干个并发的事务之间的隔离程度,与我们开发时候主要相关的场景包括:脏读取、不可重复读、幻读。

脏读 :一个事务读到了另一个事务的未提交的数据 

不可重复读 :一个事务读到了另一个事务已经提交的 update 的数据导致多次查询结果不一致. 

虚幻读 :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致.

  1. DEFAULT:这是默认值,表示使用底层数据库的默认隔离级别。对大部分数据库而言,通常这值就是:READ_COMMITTED
  2. READ_UNCOMMITTED:该隔离级别表示一个事务可以读取另一个事务修改但还没有提交的数据。该级别不能防止脏读和不可重复读,因此很少使用该隔离级别。
  3. READ_COMMITTED:该隔离级别表示一个事务只能读取另一个事务已经提交的数据。该级别可以防止脏读,这也是大多数情况下的推荐值。
  4. REPEATABLE_READ:该隔离级别表示一个事务在整个过程中可以多次重复执行某个查询,并且每次返回的记录都相同。即使在多次查询之间有新增的数据满足该查询,这些新增的记录也会被忽略。该级别可以防止脏读和不可重复读。
  5. SERIALIZABLE:所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。但是这将严重影响程序的性能。通常情况下也不会用到该级别。

Mysql 默认:可重复读 

Oracle 默认:读已提交

所谓事务的传播行为是指,如果在开始当前事务之前,一个事务上下文已经存在,此时有若干选项可以指定一个事务性方法的执行行为。

我们可以看org.springframework.transaction.annotation.Propagation枚举类中定义了6个表示传播行为的枚举值:REQUIRED:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。

PROPAGATION_REQUIRED -- 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。 

PROPAGATION_SUPPORTS -- 支持当前事务,如果当前没有事务,就以非事务方式执行。 

PROPAGATION_MANDATORY -- 支持当前事务,如果当前没有事务,就抛出异常。 

PROPAGATION_REQUIRES_NEW -- 新建事务,如果当前存在事务,把当前事务挂起。 

PROPAGATION_NOT_SUPPORTED -- 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。 

PROPAGATION_NEVER -- 以非事务方式执行,如果当前存在事务,则抛出异常。 

PROPAGATION_NESTED -- 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作

JDBC中如何进行事务处理

答:Connection提供了事务处理的方法,通过调用setAutoCommit(false)可以设置手动提交事务;当事务完成后用commit()显式提交事务;如果在事务处理过程中发生异常则通过rollback()进行事务回滚。除此之外,从JDBC 3.0中还引入了Savepoint(保存点)的概念,允许通过代码设置保存点并让事务回滚到指定的保存点。

mybaits+spring的事务处理

定义事务模板,事务管理器,事务拦截器

事务拦截器,在设置事务属性的时候,回解析配置的值,解析器

事务拦截器,执行

开启事务的时候会去寻找数据源,继而找到数据库连接。因而多数据源的时候会寻找配置的数据源的key

https://blog.csdn.net/qq_16675313/article/details/79955136

一个接口注入的时候,如果一个接口有多个实现类,则按照实现类的名称匹配bean

事务:service开启的事务,代码异常在service里面被捕捉的话不会影响sql提交,没有捕捉的话,sql会回滚。如果try,catch块中,多个sql操作,其中一个发生异常,不会影响到其他的sql提交。

事务:通一个service内部,A方法调用B方法,B方法的事务会失效,变成普通的java代码。这个时候如果A方法有事务的话B会加入进入,如果A方法没有事务的话B也不会有。A方法调用B方法会造成B方法不会走事务拦截器

如果ServiceA,A方法调用ServiceB的B方法,方法A有没有事务不会影响到方法B的事务。如果A没有事务,B有事务,那么B方法出现了异常,那么B方法会回滚,A方法不会回滚。A方法调用B方法不会造成B方法走事务拦截器。

在一个事务里面,一个数据源只会有一个connection,这个是绑定在ThreadLocal里面的,如果AB在一个事务里面,始终是在对一个connection进行操作,最后根据操作状态决定connection是commit还是rollback。dao层在操作数据的时候会去找connection(如果有事务的话就去线程里面拿,如果不是没有事务的话就去创建新的)

事务默认会遇到runtimeException的时候才会回滚,遇到java.lang.Exception不会回滚,如果想把java.lang.Exception回滚,加入如下配置“,-java.lang.Exception

<prop key="*">PROPAGATION_REQUIRES_NEW,-java.lang.Exception</prop>

线程安全,每个线程同一个数据源只有一个connection 。当线程在执行一个有事务的方法时,通过数据源去获取connection。事务

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值