springboot jdbctemplate事务,jdbctemplate操作数据库

  springboot jdbctemplate事务,jdbctemplate操作数据库

  

目录

Spring JdbcTemplate数据库事务参数I,propagation 1 . required 2 . requires _ new 3 . supports 4 . not _ supported 5 . mandatory 6 . never 7 . nested II,ioslation III,timeout IV,readOnly V,rollbackFor VI,noRollbackFor

 

  

Spring JdbcTemplate数据库事务参数

@Transactional()注释中有很多参数,其中我们常用的有:

 

  00-1010表示事务传播行为。也就是说调用多个事务方法,在这个过程中如何管理事务。

  这里的事务方法是指改变数据库表数据的方法。

  示例:

  有update()方法:

  Public void update() {}也有一个add()方法:

  Public void add() {//调用了update()方法update()}那么,现在当其中一个方法添加了transaction comment @ Transactional时,调用执行过程是什么样的?或者两个人都有交易评论怎么办?

  为了解决这个问题,有七种spring事务传播行为:

  必需:默认参数。如果有事务正在运行,当前方法将在该事务中运行;否则,将打开一个新的事务,并在它自己的事务中运行。REQUIRES_NEW:当前方法必须启动一个新的事务,并在自己的事务中运行。如果有正在进行的事务,它应该被挂起。支持:如果有一个事务正在运行,当前方法将在这个事务中运行,否则它可能不会在事务中运行。NOT_SUPPORTED:当前方法不应在事务中运行。如果有正在运行的事务,暂停它。强制:当前方法必须在事务内部运行。如果没有正在运行的事务,将会引发异常。NEVER:当前方法不应该在事务中运行。如果有正在运行的事务,将会引发异常。嵌套:如果有一个事务正在运行,当前方法应该在这个事务的嵌套事务中运行,否则,启动一个新的事务,在它自己的事务中运行。

  00-1010如果有事务正在运行,当前方法将在此事务内运行,否则,将打开一个新事务并在其自己的事务内运行。

  @Transactional(传播=传播。必选)public void methodA(){ methodB();//do something } @ transactional(propagation=propagation . required)public void method b(){//do something }调用methodA时,由于当前上下文中没有事务,会打开一个新的事务。执行到methodB时,发现当前上下文中有一个事务,于是将其添加到当前事务中执行。单独调用methodB时,将打开一个新的事务,因为当前上下文中没有事务。

  00-1010当前方法必须启动一个新的事务,并在其自己的事务内运行。如果有正在进行的事务,它应该被挂起。

  @Transactional(传播=传播。必选)public void methodA(){ doSomeThingA();methodB();doSomeThingB();//做点别的}//事务属性为requirements _ new @ transactional(propagation=propagation . requirements _ new)public void方法b () {//dosomething}调用方法时,启动事务A。当执行methodB时,启动事务B,然后挂起事务A。在执行事务B之后,继续事务A。

  这里的事务a称为外部事务。这里的事务b称为内部事务。

  00-1010如果有事务正在运行,则当前方法在此事务内运行,否则可能不会在事务内运行。

  @Transactional(p

  ropagation = Propagation.REQUIRED)public void methodA() { methodB();// do something}// 事务属性为SUPPORTS@Transactional(propagation = Propagation.SUPPORTS)public void methodB() { // do something}当调用 methodA 时,methodB 加入到 methodA 的事务中,事务的执行。当单独的调用 methodB 时,methodB方法是非事务的执行的。

  

 

  

4. NOT_SUPPORTED

当前的方法不应该运行在事务中,如果有运行的事务,将它挂起。

 

  

 

  当调用 methodA 时,开启 事务 A。当执行到 methodB 时,挂起事务A,以非事务的方式执行 methodB 。当单独的调用 methodB 时,methodB方法是非事务的执行的。

 

  

5. MANDATORY

当前的方法必须运行在事务内部,如果没有正在运行的事务,就抛出异常。

 

  

@Transactional(propagation = Propagation.REQUIRED)public void methodA() { methodB();// do something}// 事务属性为MANDATORY@Transactional(propagation = Propagation.MANDATORY)public void methodB() { // do something}

当调用 methodA 时,methodB 则加入到 methodA 的事务中,事务地执行。当单独调用 methodB 时,因为当前没有一个活动的事务,则会抛出异常。

 

  

 

  

6. NEVER

当前的方法不应该在事务中运行,如果有运行的事务,就抛出异常。

 

  

 

  

7. NESTED

如果有事务在运行,当前的方法就应该在这个事务的嵌套事务内运行,否则,就启动一个新的事务,并在自己的事务内运行。

 

  当单独执行 methodB ,开启事务 B,执行。当执行 methodA 时,开启事务 A,执行到 methodB,开启内层事务 B。注意 当执行 methodA 时,这里是一个嵌套事务。

  如果外层事务失败,则会回滚内层事务所做的操作。但是内层事务的失败不会引起外层事务的回滚。

  

 

  

二、ioslation

设置事务隔离级别。

 

  因为不同的事务隔离级别会引起不同的问题,比如:脏读、不可重复读、幻读。

  相关的内容在之前有过介绍,有兴趣的可以自行跳转过去:

  【Mysql】数据库事务,脏读、幻读、不可重复读

  所以要解决,需要设置对应的隔离级别:

  READ_UNCOMMITTED: 读未提交READ_COMMITTED: 读已提交REPEATABLE_READ: 可重复读SERIALIZABLE: 串行化

 

  

 

  

三、timeout

设置超时时间。

 

  事务需要在一定时间内进行提交,如果没提交,就回滚。

  默认值是 -1 ,表示不超时。如果设置时间,单位是秒(s)。

  

 

  

四、readOnly

设置是否只读。

 

  默认值 false,表示可以查询,也可以进行添加、修改、删除操作。

  当设置为 true,只可以进行查询操作。

  

 

  

五、rollbackFor

设置出现哪些异常后就进行事务的回滚。

 

  

 

  

六、noRollbackFor

设置出现哪些异常后,不进行事务的回滚。

 

  以上就是Spring学习JdbcTemplate数据库事务参数的详细内容,更多关于Spring JdbcTemplate数据库事务的资料请关注盛行IT其它相关文章!

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: