1. 在需要事务管理的地方加@Transactional 注解。@Transactional 注解可以被应用于接口定义和接口方法、类定义和类的 public 方法上 。

2. @Transactional 注解只能应用到 public 可见度的方法上 。 如果你在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不会报错, 但是这个被注解的方法将不会展示已配置的事务设置。

3. 注意仅仅 @Transactional 注解的出现不足于开启事务行为,它仅仅 是一种元数据。必须在配置文件中使用配置元素,才真正开启了事务行为。

4. 通过 元素的 "proxy-target-class" 属性值来控制是基于接口的还是基于类的代理被创 建。 如果 "proxy-target-class" 属值被设置为 "true",那么基于类的代理将起作用(这时需要CGLIB库cglib.jar在CLASSPATH中)。如果 "proxy-target-class" 属值被设置为 "false" 或者这个属性被省略,那么标准的JDK基于接口的代理将起作用。

< !-- JTA事务(非分布式事务), 事务配置的时候 ,不能指定dataSource属性(分布式事务,是有全局事务来管理数据库链接的)-->   
< !-- 标准的JDK基于接口的代理将起作用 -->

  1. <!-- aop切面 -->
  2. <aop:aspectj-autoproxy proxy-target-class="false" />
  3. <!-- 基于类的代理将起作用 ,同时 cglib.jar必须在CLASSPATH中 -->
  4. <!-- aop切面 -->
  5. <aop:aspectj-autoproxy proxy-target-class="true" />
<!-- aop切面 -->
<aop:aspectj-autoproxy proxy-target-class="false" /> <!-- 基于类的代理将起作用 ,同时 cglib.jar必须在CLASSPATH中 -->
<!-- aop切面 -->
<aop:aspectj-autoproxy proxy-target-class="true" />

注解@Transactional cglib与java动态代理最大区别是代理目标对象不用实现接口, 那么注解要是写到接口方法上,要是使用cglib代理,这是注解事物就失效了,为了保持兼容注解最好都写到实现类方法上。

5. Spring团队建议在具体的类(或类的方法)上使用 @Transactional 注解,而不要使用在类所要实现的任何接口上 。在接口上使用 @Transactional 注解,只能当你设置了基于接口的代理时它才生效。因为注解是 不能继承 的,这就意味着如果正在使用基于类的代理时,那么事务的设置将不能被基于类的代理所识别,而且对象也将不会被事务代理所包装。

6. @Transactional 的事务开启 ,或者是基于接口的 或者是基于类的代理被创建。所以在同一个类中一个方法调用另一个方法有事务的方法,事务是不会起作用的 。

  1. public interface PersonageTempService {
  2. //删除指定id的Personage
  3. public void del(Integer Personageid) ;
  4. //删除指定id的Personage,flag
  5. public void del(Integer Personageid,boolean flag) ;
  6. }
  7. public class PersonageTempServiceBean implements PersonageTempService {
  8. private JdbcTemplate jdbcTemplate;
  9. public void del(Integer Personageid){
  10. try{
  11. this.del(Personageid,true)
  12. System.out.println("del success");
  13. }catch(Exception e){
  14. System.out.println("del failed");
  15. }
  16. }
  17. @Transactional
  18. //此时,事务根本就没有开启, 即数据库会默认提交该操作,即记录别删除掉
  19. public void del(Integer Personageid,boolean flag){
  20. if(flag == ture){
  21. jdbcTemplate.update("del from Personage where id=?", new Object[]{Personageid}, new int[]{java.sql.Types.INTEGER});
  22. throw new RuntimeException("运行期例外");
  23. }
  24. }
  25. }
  26. public class PersonageTempServiceBeanTest{
  27. PersonageTempService ps = new PersonageTempServiceBean ();
  28. ps.del(5);
  29. }
  30. }
public interface PersonageTempService {
//删除指定id的Personage
public void del(Integer Personageid) ; //删除指定id的Personage,flag
public void del(Integer Personageid,boolean flag) ;
} public class PersonageTempServiceBean implements PersonageTempService {
private JdbcTemplate jdbcTemplate; public void del(Integer Personageid){
try{
this.del(Personageid,true)
System.out.println("del success");
}catch(Exception e){
System.out.println("del failed");
}
} @Transactional
//此时,事务根本就没有开启, 即数据库会默认提交该操作,即记录别删除掉
public void del(Integer Personageid,boolean flag){
if(flag == ture){
jdbcTemplate.update("del from Personage where id=?", new Object[]{Personageid}, new int[]{java.sql.Types.INTEGER});
throw new RuntimeException("运行期例外");
}
}
} public class PersonageTempServiceBeanTest{
PersonageTempService ps = new PersonageTempServiceBean ();
ps.del(5);
}
}

7. Spring使用声明式事务处理,默认情况下, 如果被注解的数据库操作方法中发生了unchecked异常,所有的数据库操作将rollback ;如果发生的异常是checked异常,默认情况下数 据库操作还是会提 交的。

  1. public interface PersonageService {
  2. //删除指定id的Personage
  3. public void del(Integer Personageid) ;
  4. //获取Personage
  5. public Personage getPersonage(Integer Personageid);
  6. }
  7. //PersonageServiceBean 实现了PersonageService 接口,则基于接口的还是基于类的代理 都可以实现事务
  8. @Transactional public class PersonageServiceBean implements PersonageService {
  9. private JdbcTemplate jdbcTemplate;
  10. //发生了unchecked异常,事务回滚, @Transactional
  11. public void del(Integer Personageid){
  12. jdbcTemplate.update("del from Personage where id=?", new Object[]{Personageid},
  13. new int[]{java.sql.Types.INTEGER});
  14. throw new RuntimeException("运行期例外");
  15. }
  16. }
  17. public interface PersonageService {
  18. //删除指定id的Personage
  19. public void delete(Integer Personageid) throws Exception;
  20. //获取Personage
  21. public Personage getPersonage(Integer Personageid);
  22. }
  23. @Transactional
  24. public class PersonageServiceBean implements PersonageService {
  25. //发生了checked异常,事务不回滚,即数据库记录仍能被删除,
  26. //checked的例外,需要我们在外部用try/catch语法对调用该方法的地方进行包含 @Transactional
  27. public void delete(Integer Personageid) throws Exception{
  28. jdbcTemplate.update("delete from Personage where id=?", new Object[]{Personageid},
  29. new int[]{java.sql.Types.INTEGER});
  30. throw new Exception("运行期例外");
  31. }
  32. }
public interface PersonageService {
//删除指定id的Personage
public void del(Integer Personageid) ; //获取Personage
public Personage getPersonage(Integer Personageid);
} //PersonageServiceBean 实现了PersonageService 接口,则基于接口的还是基于类的代理 都可以实现事务
@Transactional public class PersonageServiceBean implements PersonageService {
private JdbcTemplate jdbcTemplate; //发生了unchecked异常,事务回滚, @Transactional
public void del(Integer Personageid){
jdbcTemplate.update("del from Personage where id=?", new Object[]{Personageid},
new int[]{java.sql.Types.INTEGER});
throw new RuntimeException("运行期例外");
}
} public interface PersonageService {
//删除指定id的Personage
public void delete(Integer Personageid) throws Exception; //获取Personage
public Personage getPersonage(Integer Personageid);
} @Transactional
public class PersonageServiceBean implements PersonageService { //发生了checked异常,事务不回滚,即数据库记录仍能被删除,
//checked的例外,需要我们在外部用try/catch语法对调用该方法的地方进行包含 @Transactional
public void delete(Integer Personageid) throws Exception{
jdbcTemplate.update("delete from Personage where id=?", new Object[]{Personageid},
new int[]{java.sql.Types.INTEGER});
throw new Exception("运行期例外");
}
}

但是,对于checked这种例外,默认情况下它是不会进行事务回滚的,但是 如果我们需要它进行事务回滚,这时候可以在delete方法上通过@Transaction这个注解来修改它的行为。

  1. @Transactional
  2. public class PersonServiceBean implements PersonService {
  3. @Transactional(rollbackFor=Exception.class)
  4. //rollbackFor这属性指定了,既使你出现了checked这种例外,那么它也会对事务进行回滚
  5. public void delete(Integer personid) throws Exception{
  6. jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
  7. new int[]{java.sql.Types.INTEGER});
  8. throw new Exception("运行期例外");
  9. }
  10. }
@Transactional
public class PersonServiceBean implements PersonService { @Transactional(rollbackFor=Exception.class)
//rollbackFor这属性指定了,既使你出现了checked这种例外,那么它也会对事务进行回滚
public void delete(Integer personid) throws Exception{
jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
new int[]{java.sql.Types.INTEGER});
throw new Exception("运行期例外");
}
}

在PersonServiceBean这个业务bean里面,有一些事务是不需要事务管理的,好比说获取数据的getPersons方法,getPerson方法。因为@Transactional 放在了类的上面。

此时,可 以采用propagation这个事务属性 @Transactional(propagation=Propagation.NOT_SUPPORTED),propagation这个属性指定了 事务传播行为,我们可以指定它不支持事务,当我们这么写了之后,Spring容器在getPersons方法执行前就不会开启事务 .

    1. @Transactional
    2. public class PersonServiceBean implements PersonService {
    3. @Transactional(propagation=Propagation.NOT_SUPPORTED)
    4. //则此方法 就不会开启事务了
    5. public Person getPerson(Integer personid)
    6. {
    7. }
    8. }

@Transactional spring 配置事务 注意事项的更多相关文章

  1. [转]@Transactional spring 配置事务 注意事项

    @Transactional spring 配置事务 注意事项 [@more@] @Transactional spring 配置事务 注意事项 1. 在需要事务管理的地方加@Transactiona ...

  2. Spring Boot 中使用 @Transactional 注解配置事务管理

    事务管理是应用系统开发中必不可少的一部分.Spring 为事务管理提供了丰富的功能支持.Spring 事务管理分为编程式和声明式的两种方式.编程式事务指的是通过编码方式实现事务:声明式事务基于 AOP ...

  3. Spring Boot中使用@Transactional注解配置事务管理

    事务管理是应用系统开发中必不可少的一部分.Spring 为事务管理提供了丰富的功能支持.Spring 事务管理分为编程式和声明式的两种方式.编程式事务指的是通过编码方式实现事务:声明式事务基于 AOP ...

  4. Spring配置事务 http://www.cnblogs.com/leiOOlei/p/3725911.html

    http://www.cnblogs.com/leiOOlei/p/3725911.html JNDI方式配置数据源: <?xml version="1.0" encodin ...

  5. Spring 配置 事务的几种方式

    Spring配置文件中关于事务配置总是由三个组成部分,DataSource.TransactionManager和代理机制这三部分,无论是那种配置方法,一般变化的只是代理机制这块! 首先我创建了两个类 ...

  6. Spring配置事务的五种方式

    Java事务的类型有三种: JDBC事务. 可以将多个 SQL 语句结合到一个事务中.JDBC 事务的一个缺点是事务的范围局限于一个数据库连接.一个 JDBC 事务不能跨越多个数据库 JTA(Java ...

  7. Spring配置事务中的 transactionAttributes 各属性含义及XML配置

    转自:https://blog.csdn.net/z69183787/article/details/17161393 transactionAttributes 属性: PROPAGATION 事务 ...

  8. springboot使用 @Transactional 注解配置事务管理

    介绍 springboot对数据库事务的使用非常的方便,只需要在方法上添加@Transactional注解即可.Spring 为事务管理提供了丰富的功能支持.Spring 事务管理分为编程式和声明式的 ...

  9. spring 配置事务管理器

    在Spring中数据库事务是通过PlatformTransactionManager进行管理的,jdbcTemplate是不能支持事务的,而能够支持事务的是org.springframework.tr ...

随机推荐

  1. JavaScript自定义对象

    一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...

  2. LuoGu P1352 没有上司的舞会

    题目传送门 这可能是最简单的树形Dp了吧 对于每个人,要么他来,他的下属不来 要么他不来,他的下属爱来不来 于是设计状态: f[i][0/1]表示以i为根的子树中最大能达到的快乐值(i这个人选或者不选 ...

  3. mysql5.7设置简单密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

    注:本文来源于<  mysql5.7设置简单密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy r ...

  4. kafka消息存储与partition副本原理

    消息的存储原理: 消息的文件存储机制: 前面我们知道了一个 topic 的多个 partition 在物理磁盘上的保存路径,那么我们再来分析日志的存储方式.通过 ll /tmp/kafka-logs/ ...

  5. algorithm与numeric的一些常用函数

    numeric中的accumulated的基本用法: 来自:https://blog.csdn.net/u011499425/article/details/52756242 #include < ...

  6. 【mysql】删除字段的最后一个字符

    场景:在存入16进制id时,由于转换失误,得到的结果是0x1001L的格式,我希望转换为0x1001,去掉最后的L 指令: update tb_test set hexid=left(hexid, l ...

  7. 如何在PDF中添加水印,PDF添加水印技巧

    PDF文件现在的使用很是普遍,不管是工作中还是学习中都会使用到PDF文件,制作一个PDF文件就很辛苦的,我们要是想把PDF文件中添加水印防止抄袭的时候应该要怎么做呢,其实吧PDF文件添加水印还挺简单的 ...

  8. cf自训6

    cf946D 背包+区间dp 好题 /* 先预处理出每行消去i个1后可以的到的最小时间: 先求每行的前缀和,枚举左端点和右端点,消去的1 cost=tot-sum[r]+sum[l-1],区间长度=r ...

  9. 高斯消元模板!!!bzoj1013

    /* 高斯消元模板题 n维球体确定圆心必须要用到n+1个点 设圆心坐标(x1,x2,x3,x4...xn),半径为C 设第i个点坐标为(ai1,ai2,ai3,,,ain)那么对应的方程为 (x1-a ...

  10. python3 HTMLTestRunner.py

    """ A TestRunner for use with the Python unit testing framework. It generates a HTML ...