Spring入门Blog[十二、Spring中Annotation声明事务]

原创 2015年12月23日 11:43:42

转自:http://blog.csdn.net/zhang6622056/article/details/7702579


Spring的声明式事务Annotation的实现------AOP应用

首先先讨论一个问题:

事务放在service层还是放在dao层呢?

Dao层只是针对于某一个实体进行CRUD的操作。如果在增加删除一个表的时候。比如USER我们要在LOG表中记录相应的日志。那么在DAO层如何完成。所以说Service层可能操作多个实体类。所以事务加载service层比较合适。因为不论我们保存哪一个实例出现了错误我们都可以回滚。而不是Log插入了,User没插入。反之亦然,这都是我们不愿意看到的。

 

下面举例Spring中事务通过Annotation方式是如何实现的:

1、  加入tx开头的命名空间并且配置事务manager和driven。代码如下:

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"  
  4.     xmlns:aop="http://www.springframework.org/schema/aop"  
  5.      xmlns:tx="http://www.springframework.org/schema/tx"  
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans   
  7.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  8.            http://www.springframework.org/schema/context  
  9.            http://www.springframework.org/schema/context/spring-context-2.5.xsd  
  10.            http://www.springframework.org/schema/tx  
  11.            http://www.springframework.org/schema/tx/spring-tx-2.5.xsd  
  12.            http://www.springframework.org/schema/aop  
  13.            http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">  
  14.     <context:annotation-config />  
  15.     <!-- 配置容器资源扫描的包 -->  
  16.     <context:component-scan base-package="com.spring" />  
  17.     <!-- 将前面类写入容器 -->  
  18.     <bean id="logInterceptor" class="com.spring.aop.LogInterceptor" />  
  19.   
  20.   
  21.   
  22.     <!--  
  23.         配置数据源 <bean id="myDataSource"  
  24.         class="org.apache.commons.dbcp.BasicDataSource"  
  25.         destroy-method="close"> <property name="driverClassName"  
  26.         value="com.mysql.jdbc.Driver"/> <property name="url"  
  27.         value="jdbc:mysql://localhost:3306/sms"/> <property name="username"  
  28.         value="root"/> <property name="password" value="root"/> </bean>  
  29.     -->  
  30.   
  31.       
  32.     <!-- placeholder 占位符 -->  
  33.     <bean  
  34.         class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  35.         <property name="locations">  
  36.             <value>classpath:jdbc.properties</value>  
  37.         </property>  
  38.     </bean>  
  39.     <!-- 配置dataSource -->  
  40.     <bean id="dataSource" destroy-method="close"  
  41.         class="org.apache.commons.dbcp.BasicDataSource">  
  42.         <property name="driverClassName" value="${jdbc.driverClassName}" />  
  43.         <property name="url" value="${jdbc.url}" />  
  44.         <property name="username" value="${jdbc.username}" />  
  45.         <property name="password" value="${jdbc.password}" />  
  46.     </bean>  
  47.   
  48.     <!-- 将配置好的dataSource注入到SessionFactory中-->  
  49.     <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
  50.     <property name="dataSource" ref="dataSource"/>  
  51.     <property name="mappingResources">  
  52.       <list>  
  53.         <value>com/spring/model/user.hbm.xml</value>  
  54.         <value>com/spring/model/userlog.hbm.xml</value>  
  55.       </list>  
  56.     </property>  
  57.     <property name="hibernateProperties">  
  58.       <value>  
  59.         hibernate.dialect=org.hibernate.dialect.MySQLDialect  
  60.         hibernate.show_sql=true  
  61.         hibernate.hbm2ddl.auto=create  
  62.       </value>  
  63.     </property>  
  64.   </bean>  
  65.       
  66.       
  67.     <!-- 声明式事务管理,事务需要数据源,从sessionFactory中拿到  
  68.     这是一个AOP的应用 -->  
  69. <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  70.   <property name="sessionFactory" ref="sessionFactory" />  
  71. </bean>  
  72. <!-- 声明式事务注解的配置 -->  
  73. <tx:annotation-driven />  
  74. </beans>  
2、在Java文件上使用注解标签:
  1. //在Service层加入事务的控制。具体逻辑不在给予。  
  2. //在下面方法前面加逻辑  
  3.     /*事务的传播性。如果当前执行环境中有事务,那么则会一直在 
  4.      * 传播环境中传播下去。如果没有事务那么则会创建一个事务 
  5.     */  
  6.     @Transactional(propagation=Propagation.REQUIRED)  
  7.     public void save(User u){  
  8.         u.setName("zhanglong");  
  9.         UserLog log = new UserLog();  
  10.         log.setMsg("user added");  
  11.         userDaoImpl.save(u);  
  12.         userLogDaoImpl.save(log);  
  13.     } 
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

windows server 2012 AD 活动目录部署系列(二)创建域控制器

二 创建域控制器 上一篇我们进行了DNS配置,有了 DNS 的支持,我们现在可以开始创建域控制器了,域控制器是域中的第一台服务器,域控制器上存储着 Active Directory,可以说,域控制器...

深入理解Windows域概念

原文地址:http://angerfire.blog.51cto.com/198455/43217 在说域这个概念之前,我们先来回忆一下工作组.  首先,工作组中,每一台计算机都独立维护自己的...

oracle中常用函数大全

1、数值型常用函数    函数  返回值            样例           显示 ceil(n) 大于或等于数值n的最小整数  select ceil(10.6) from ...

oracle 函数大全及运算符

一、函数 1、取整  mod(2,10)=2  2、取整 trunc(12/10)=1 3、取整 ceil(12/10) =2 4、空(null)指定某个值  nvl(null,9)=9 5...

oracle常用函数详解(详细)

Oracle SQL 提供了用于执行特定操作的专用函数。这些函数大大增强了 SQL 语言的功能。函数可以接受零个或者多个输入参数,并返回一个输出结果。 Oracle 数据库中主要使用两种类型的函数: ...

ORACLE日期函数大全!

ORACLE日期函数大全! 2009-03-12 14:16:10日期函数 Oracle PL/SQL Oracle的日期函数相信很多人都有过统计某些数据的经历,比如,要统计财务的情况,可能要按每年...

listagg实现数据库行转列

listagg实现数据库行转列

ORACLE函数大全

常用oracle函数 SQL中的单记
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)