Spring -- spring结合aop 进行 tx&aspectj事务管理配置方法
1. tx 配置方法, 代码示例
javabean及其映射文件省略,和上篇的一样
CustomerDao.java, dao层接口
- public interface CustomerDao {
- public void insertCustomer(Customer c);
- public void updateCustomer(Customer c);
- public List<Customer> findCustomerByName(String name);
- //批量保存
- //public void saveCustomers(List<Customer> list);
- }
CustomerDaoImpl.java ,dao层实现
- public class CustomerDaoImpl implements CustomerDao {
- private SessionFactory sf ;
- public void setSf(SessionFactory sf) {
- this.sf = sf;
- }
- public List<Customer> findCustomerByName(String name) {
- String hql = "from Customer c where c.name = ?";
- Query q = sf.getCurrentSession().createQuery(hql);
- q.setString(0, name);
- return q.list();
- }
- public void insertCustomer(Customer c) {
- sf.getCurrentSession().save(c);
- }
- public void updateCustomer(Customer c) {
- sf.getCurrentSession().update(c);
- }
- }
CustomerService.java ,service层接口
- public interface CustomerService {
- public void insertCustomer(Customer c);
- public void updateCustomer(Customer c);
- public List<Customer> findCustomerByName(String name);
- //批量保存
- public void saveCustomers(List<Customer> list);
- }
CustomerServiceImpl.java,service层实现
- public class CustomerServiceImpl implements CustomerService {
- //dao
- private CustomerDao dao ;
- //注入dao
- public void setDao(CustomerDao dao) {
- this.dao = dao;
- }
- public List<Customer> findCustomerByName(String name) {
- return dao.findCustomerByName(name);
- }
- public void insertCustomer(Customer c) {
- dao.insertCustomer(c);
- }
- /**
- * 批量保存, 编程式事务管理
- */
- public void saveCustomers(final List<Customer> list) {
- for(Customer c : list){
- this.insertCustomer(c);
- }
- }
- public void updateCustomer(Customer c) {
- dao.updateCustomer(c);
- }
- }
jdbc.properties
- jdbc.driverclass=com.mysql.jdbc.Driver
- jdbc.url=jdbc:mysql://localhost:3306/spring
- jdbc.username=root
- jdbc.password=root
- c3p0.pool.size.max=10
- c3p0.pool.size.min=2
- c3p0.pool.size.ini=3
- c3p0.pool.size.increment=2
- hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
- hibernate.show_sql=true
- hibernate.hbm2ddl.auto=none
sh.xml,spring配置文件
- <?xml version="1.0"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-2.5.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-2.5.xsd ">
- <!-- 指定分散配置的文件的位置 -->
- <context:property-placeholder location="classpath:cn/itcast/spring/hibernate/tx25/jdbc.properties" />
- <!-- 配置c3p0数据源 -->
- <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
- <property name="driverClass" value="${jdbc.driverclass}" />
- <property name="jdbcUrl" value="${jdbc.url}" />
- <property name="user" value="${jdbc.username}" />
- <property name="password" value="${jdbc.password}" />
- <property name="maxPoolSize" value="${c3p0.pool.size.max}" />
- <property name="minPoolSize" value="${c3p0.pool.size.min}" />
- <property name="initialPoolSize" value="${c3p0.pool.size.ini}" />
- <property name="acquireIncrement" value="${c3p0.pool.size.increment}" />
- </bean>
- <!-- 本地回话工厂bean,spring整合hibernate的核心入口 -->
- <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
- <property name="dataSource" ref="dataSource" />
- <!-- 指定hibernate自身的属性 -->
- <property name="hibernateProperties">
- <props>
- <prop key="hibernate.dialect">${hibernate.dialect}</prop>
- <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
- <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
- </props>
- </property>
- <property name="mappingDirectoryLocations">
- <list>
- <value>classpath:cn/itcast/spring/domain</value>
- </list>
- </property>
- </bean>
- <!-- customerDao -->
- <bean id="customerDao" class="cn.itcast.spring.hibernate.tx25.CustomerDaoImpl">
- <property name="sf" ref="sessionFactory" />
- </bean>
- <!-- hibernate事务管理器,在service层面上实现事务管理,而且达到平台无关性 -->
- <bean id="htm" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
- <property name="sessionFactory" ref="sessionFactory" />
- </bean>
- <!-- customerService -->
- <bean id="customerService" class="cn.itcast.spring.hibernate.tx25.CustomerServiceImpl">
- <property name="dao" ref="customerDao" />
- </bean>
- <!-- 事务通知 -->
- <tx:advice id="txAdvice" transaction-manager="htm">
- <!-- 事务属性 -->
- <tx:attributes>
- <tx:method name="insert*" propagation="REQUIRED" isolation="DEFAULT"/>
- <tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT"/>
- <tx:method name="update*" propagation="REQUIRED" isolation="DEFAULT"/>
- <tx:method name="delete*" propagation="REQUIRED" isolation="DEFAULT"/>
- <tx:method name="batch*" propagation="REQUIRED" isolation="DEFAULT"/>
- <tx:method name="load*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>
- <tx:method name="get*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>
- <tx:method name="find*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>
- <tx:method name="*" propagation="SUPPORTS" isolation="DEFAULT" read-only="false"/>
- </tx:attributes>
- </tx:advice>
- <!-- aop配置(配置切入点) -->
- <aop:config>
- <aop:pointcut id="txPointcut" expression="execution(* *..*Service.*(..))"/>
- <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut" />
- </aop:config>
- </beans>
App.java 测试代码
- public class App {
- public static void main(String[] args) throws SQLException {
- ApplicationContext ac = new ClassPathXmlApplicationContext(
- "cn/itcast/spring/hibernate/tx25/sh.xml");
- CustomerService cs = (CustomerService) ac.getBean("customerService");
- List<Customer> list = new ArrayList<Customer>();
- Customer c = null ;
- for(int i = 0 ; i < 10 ; i++){
- c = new Customer();
- if(i == 9){
- c.setName(null);
- }
- else{
- c.setName("tom" + i);
- }
- c.setAge(20 + i);
- list.add(c);
- }
- cs.saveCustomers(list);
- }
- }
2. aspectj 配置方法 代码示例
和(1)tx方式相比只有两个文件有变动
CustomerServiceImpl.java, service实现 以加注解的方式
- /**
- * 通过注解方法实现事务管理
- */
- @Transactional(propagation=Propagation.REQUIRED,isolation=Isolation.DEFAULT)
- public class CustomerServiceImpl implements CustomerService {
- //dao
- private CustomerDao dao ;
- //注入dao
- public void setDao(CustomerDao dao) {
- this.dao = dao;
- }
- /**
- * 只读
- */
- @Transactional(readOnly=true)
- public List<Customer> findCustomerByName(String name) {
- return dao.findCustomerByName(name);
- }
- public void insertCustomer(Customer c) {
- dao.insertCustomer(c);
- }
- /**
- * 批量保存, 编程式事务管理
- */
- public void saveCustomers(final List<Customer> list) {
- for(Customer c : list){
- this.insertCustomer(c);
- }
- }
- public void updateCustomer(Customer c) {
- dao.updateCustomer(c);
- }
- }
sh.xml 配置文件
- <?xml version="1.0"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-2.5.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-2.5.xsd ">
- <!-- 指定分散配置的文件的位置 -->
- <context:property-placeholder location="classpath:cn/itcast/spring/hibernate/tx25/jdbc.properties" />
- <!-- 配置c3p0数据源 -->
- <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
- <property name="driverClass" value="${jdbc.driverclass}" />
- <property name="jdbcUrl" value="${jdbc.url}" />
- <property name="user" value="${jdbc.username}" />
- <property name="password" value="${jdbc.password}" />
- <property name="maxPoolSize" value="${c3p0.pool.size.max}" />
- <property name="minPoolSize" value="${c3p0.pool.size.min}" />
- <property name="initialPoolSize" value="${c3p0.pool.size.ini}" />
- <property name="acquireIncrement" value="${c3p0.pool.size.increment}" />
- </bean>
- <!-- 本地回话工厂bean,spring整合hibernate的核心入口 -->
- <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
- <property name="dataSource" ref="dataSource" />
- <!-- 指定hibernate自身的属性 -->
- <property name="hibernateProperties">
- <props>
- <prop key="hibernate.dialect">${hibernate.dialect}</prop>
- <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
- <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
- </props>
- </property>
- <property name="mappingDirectoryLocations">
- <list>
- <value>classpath:cn/itcast/spring/domain</value>
- </list>
- </property>
- </bean>
- <!-- customerDao -->
- <bean id="customerDao" class="cn.itcast.spring.hibernate.aspectj.CustomerDaoImpl">
- <property name="sf" ref="sessionFactory" />
- </bean>
- <!-- hibernate事务管理器,在service层面上实现事务管理,而且达到平台无关性 -->
- <bean id="htm" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
- <property name="sessionFactory" ref="sessionFactory" />
- </bean>
- <!-- customerService -->
- <bean id="customerService" class="cn.itcast.spring.hibernate.aspectj.CustomerServiceImpl">
- <property name="dao" ref="customerDao" />
- </bean>
- <!-- 使用注解驱动 -->
- <tx:annotation-driven transaction-manager="htm"/>
- </beans>
Spring -- spring结合aop 进行 tx&aspectj事务管理配置方法的更多相关文章
- spring,mybatis事务管理配置与@Transactional注解使用[转]
spring,mybatis事务管理配置与@Transactional注解使用[转] spring,mybatis事务管理配置与@Transactional注解使用 概述事务管理对于企业应用来说是至关 ...
- Spring整合Hibernate 二 - 声明式的事务管理
Spring大战Hibernate之声明式的事务管理 Spring配置文件: 添加事务管理类的bean: <bean id="txManager" class="o ...
- spring + ibatis 多数据源事务(分布式事务)管理配置方法(转)
spring + ibatis 多数据源事务(分布式事务)管理配置方法(转) .我先要给大家讲一个概念:spring 的多数据源事务,这是民间的说法.官方的说法是:spring 的分布式事务.明白了这 ...
- spring,mybatis事务管理配置与@Transactional注解使用
spring,mybatis事务管理配置与@Transactional注解使用[转] spring,mybatis事务管理配置与@Transactional注解使用 概述事务管理对于企业应用来说是 ...
- Spring事务管理配置以及异常处理
Spring事务管理配置: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...
- spring 事物(三)—— 声明式事务管理详解
spring的事务处理分为两种: 1.编程式事务:在程序中控制事务开始,执行和提交:详情请点此跳转: 2.声明式事务:在Spring配置文件中对事务进行配置,无须在程序中写代码:(建议使用) 我对&q ...
- Spring Boot 2.x基础教程:事务管理入门
什么是事务? 我们在开发企业应用时,通常业务人员的一个操作实际上是对数据库读写的多步操作的结合.由于数据操作在顺序执行的过程中,任何一步操作都有可能发生异常,异常会导致后续操作无法完成,此时由于业务逻 ...
- [Spring-AOP-XML] 利用Spirng中的AOP和XML进行事务管理
Spring中的AOP进行事务管理有三种方式 A.自定义事务切面 利用AspectJ来编写事务,我们一般把这个切面作用在service层中.其他代码在下面 编写一个Transaction实现类,通过S ...
- spring3.0事务管理配置
转载:http://war-martin.iteye.com/blog/1396335 第一种配置方法:基于XML的事务管理 这种方法不需要对原有的业务做任何修改,通过在XML文件中定义需要拦截方法的 ...
随机推荐
- 【BZOJ2259】[Oibh]新型计算机 最短路
[BZOJ2259][Oibh]新型计算机 Description Tim正在摆弄着他设计的“计算机”,他认为这台计算机原理很独特,因此利用它可以解决许多难题. 但是,有一个难题他却解决不了,是这台计 ...
- Java核心技术1
Java方法参数的使用情况: 一个方法不能修改一个基本数据 对象析构与finalize方法 Java有自动的垃圾回收器,不需要人工回收内存,例如,文件或使用了系统资源的另一个对象的句柄.在这种情况下, ...
- GRPC使用错误排查记录
1. 编译报错 f.fr.SetReuseFrames undefined (type *http2.Framer has no field or method SetReuseFrames) 该问题 ...
- mysql_表内容_操作
1.增 语法:insert into 表 (列名,列名...) values (值,值...) # 插入单条数据 insert into 表 (列名,列名...) values (值,值...) # ...
- 翻页bug 在接口文档中应规范参数的取值区间
<?php$a=array("red","green","blue","yellow","brown&q ...
- 获取文档版本版本值 滚动标识符 游标 控制查询如何执行 控制查询在哪些分片执行 boost加权
映射mapping.json{ "book": { "_index": { "enabled": true }, "_id&quo ...
- 利用epoll实现异步IO
之前异步IO一直没搞明白,大致的理解就是在一个大的循环中,有两部分:第一部分是监听事件:第二部分是处理事件(通过添加回调函数的方式).就拿网络通信来说,可以先通过调用 select 模块中的 sele ...
- Milking Time---poj3616(简单dp)
题目链接:http://poj.org/problem?id=3616 题意:人从奶牛身上挤奶有m个时间段(1----n),每个时间段包含 s e f 表示从 s 到 e 的这段时间可以获得 f 单位 ...
- Learning How to Learn学习笔记(转)
add by zhj: 工作中提高自己水平的最重要的一点是——快速的学习能力.这篇文章就是探讨这个问题的,掌握了快速学习能力的规律,你自然就有了快速学习能力了. 原文:Learning How to ...
- docker中制作自己的JDK+tomcat镜像
方式一 首先,准备好想要的jdk和tomcat,另外,我们需要创建一个Dockerfile文件.下面展示一个Dockerfile文件的完整内容: FROM ubuntu:14.10 MAINTAINE ...