zoukankan      html  css  js  c++  java
  • spring 注解事务配置

    1.数据库准备




    2.jar包准备


    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    	<modelVersion>4.0.0</modelVersion>
    	<groupId>com.zhaochao.spring</groupId>
    	<artifactId>AOPDeme</artifactId>
    	<packaging>war</packaging>
    	<version>0.0.1-SNAPSHOT</version>
    	<name>AOPDeme Maven Webapp</name>
    	<url>http://maven.apache.org</url>
    
    
    	<properties>
    		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    		<org.springframework.version>4.1.6.RELEASE</org.springframework.version>
    		<project.version>1.0.0-SNAPSHOT</project.version>
    		<junit.version>4.12</junit.version>
    		<mysql.version>5.1.21</mysql.version>
    		<log4j.version>1.2.17</log4j.version>
    		<fastjson.version>1.2.7</fastjson.version>
    	</properties>
    
    	<dependencies>
    
    		<!-- junit 测试包 -->
    		<dependency>
    			<groupId>junit</groupId>
    			<artifactId>junit</artifactId>
    			<version>${junit.version}</version>
    			<scope>test</scope>
    		</dependency>
    		<!-- 此处开始就是Spring 所有的jar了,spring3.0的jar包拆分了,所以很多 -->
    		<!-- Core utilities used by other modules. Define this if you use Spring 
    			Utility APIs (org.springframework.core.*/org.springframework.util.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-core</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Expression Language (depends on spring-core) Define this if you use 
    			Spring Expression APIs (org.springframework.expression.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-expression</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Bean Factory and JavaBeans utilities (depends on spring-core) Define 
    			this if you use Spring Bean APIs (org.springframework.beans.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-beans</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Aspect Oriented Programming (AOP) Framework (depends on spring-core, 
    			spring-beans) Define this if you use Spring AOP APIs (org.springframework.aop.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-aop</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Application Context (depends on spring-core, spring-expression, spring-aop, 
    			spring-beans) This is the central artifact for Spring's Dependency Injection 
    			Container and is generally always defined -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-context</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    
    
    		<!-- Transaction Management Abstraction (depends on spring-core, spring-beans, 
    			spring-aop, spring-context) Define this if you use Spring Transactions or 
    			DAO Exception Hierarchy (org.springframework.transaction.*/org.springframework.dao.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-tx</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- JDBC Data Access Library (depends on spring-core, spring-beans, spring-context, 
    			spring-tx) Define this if you use Spring's JdbcTemplate API (org.springframework.jdbc.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-jdbc</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    
    
    		<!-- Web application development utilities applicable to both Servlet and 
    			Portlet Environments (depends on spring-core, spring-beans, spring-context) 
    			Define this if you use Spring MVC, or wish to use Struts, JSF, or another 
    			web framework with Spring (org.springframework.web.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-web</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Spring MVC for Servlet Environments (depends on spring-core, spring-beans, 
    			spring-context, spring-web) Define this if you use Spring MVC with a Servlet 
    			Container such as Apache Tomcat (org.springframework.web.servlet.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-webmvc</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Spring MVC for Portlet Environments (depends on spring-core, spring-beans, 
    			spring-context, spring-web) Define this if you use Spring MVC with a Portlet 
    			Container (org.springframework.web.portlet.*) -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-webmvc-portlet</artifactId>
    			<version>${org.springframework.version}</version>
    		</dependency>
    
    		<!-- Support for testing Spring applications with tools such as JUnit and 
    			TestNG This artifact is generally always defined with a 'test' scope for 
    			the integration testing framework and unit testing stubs -->
    		<dependency>
    			<groupId>org.springframework</groupId>
    			<artifactId>spring-test</artifactId>
    			<version>${org.springframework.version}</version>
    			<scope>test</scope>
    		</dependency>
    		<!-- 上面的都是Spring的jar包,可以选择性的添加 -->
    
    		<dependency>
    			<groupId>javax.servlet</groupId>
    			<artifactId>javax.servlet-api</artifactId>
    			<version>3.1.0</version>
    		</dependency>
    
    
    		<!-- mysql的数据库驱动包 -->
    		<dependency>
    			<groupId>mysql</groupId>
    			<artifactId>mysql-connector-java</artifactId>
    			<version>${mysql.version}</version>
    		</dependency>
    
    
    		<!-- 日志打印 log4j包 -->
    		<dependency>
    			<groupId>log4j</groupId>
    			<artifactId>log4j</artifactId>
    			<version>${log4j.version}</version>
    		</dependency>
    
    
    
    		<!-- 日志记录依赖包,很多都依赖此包,像log4j,json-lib等等 -->
    		<dependency>
    			<groupId>commons-logging</groupId>
    			<artifactId>commons-logging</artifactId>
    			<version>1.1.1</version>
    			<scope>provided</scope>
    		</dependency>
    
    
    		<!-- 下面的三个包是在配置事务的时候用到的 spring的依赖包 -->
    		<dependency>
    			<groupId>org.aspectj</groupId>
    			<artifactId>aspectjweaver</artifactId>
    			<version>1.7.0</version>
    		</dependency>
    		<dependency>
    			<groupId>aopalliance</groupId>
    			<artifactId>aopalliance</artifactId>
    			<version>1.0</version>
    		</dependency>
    		<dependency>
    			<groupId>cglib</groupId>
    			<artifactId>cglib-nodep</artifactId>
    			<version>2.2.2</version>
    		</dependency>
    		<!-- 阿里巴巴fastjson -->
    		<dependency>
    			<groupId>com.alibaba</groupId>
    			<artifactId>fastjson</artifactId>
    			<version>${fastjson.version}</version>
    		</dependency>
    
    		<!-- 阿里巴巴 druid数据源 -->
    		<dependency>
    			<groupId>com.alibaba</groupId>
    			<artifactId>druid</artifactId>
    			<version>1.0.13</version>
    		</dependency>
    
    		<!-- c3p0 dataSource -->
    		<dependency>
    			<groupId>c3p0</groupId>
    			<artifactId>c3p0</artifactId>
    			<version>0.9.1.2</version>
    		</dependency>
    		<!-- tomcat-jdbc pool -->
    		<dependency>
    			<groupId>org.apache.tomcat</groupId>
    			<artifactId>tomcat-jdbc</artifactId>
    			<version>8.0.28</version>
    		</dependency>
    
    
    		<!-- DBCP -->
    		<dependency>
    			<groupId>org.apache.commons</groupId>
    			<artifactId>commons-dbcp2</artifactId>
    			<version>2.1.1</version>
    		</dependency>
    
    
    	</dependencies>
    	<build>
    		<finalName>AOPDeme</finalName>
    	</build>
    </project>
    

    3.项目目录结构



    4.接口定义

    package com.zhaochao.service;
    
    public interface IAccountDao {
    	public void addMoney(int id,int money);
    	public void subMoney(int id,int money);
    }
    
    package com.zhaochao.service;
    
    public interface IAccountService {
    	public void giveMoney();
    }
    

    5.实现类

    package com.zhaochao.service;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.stereotype.Component;
    
    @Component("accountDao")
    public class AccountDaoImple implements IAccountDao {
    	@Autowired
    	private JdbcTemplate jdbcTemplate;
    
    	public void addMoney(int id, int money) {
    		// TODO Auto-generated method stub
    		jdbcTemplate.execute("update user_money set money=money-100 where id="+id);
    		
    	}
    
    	public void subMoney(int id, int money) {
    		// TODO Auto-generated method stub
    		jdbcTemplate.execute("update user_money set  money=money+100 where id="+id);
    	}
    
    	
    }
    

    package com.zhaochao.service;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Isolation;
    import org.springframework.transaction.annotation.Propagation;
    import org.springframework.transaction.annotation.Transactional;
    
    @Service("accountService")
    public class AccountServiceImpl implements IAccountService {
    	
    	@Autowired
    	private IAccountDao accountDao;
    
    	@Transactional(isolation=Isolation.REPEATABLE_READ,propagation=Propagation.REQUIRED)
    	public void giveMoney() {
    		// TODO Auto-generated method stub
    		accountDao.subMoney(1, 100);
    		int i=1/0;
    		accountDao.addMoney(2, 100);
    		
    	}
    	
    	
    	
    	
    }
    

    6.spring及log4j配置

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    
    	<!-- 开发时输出控制台 上线后取消-->
    	<appender name="LOG.CONSOLE" class="org.apache.log4j.ConsoleAppender">
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d - %c -%-4r [%t] %-5p %x - %m%n" />
    		</layout>
    		<!--限制输出级别 -->
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMax" value="ERROR" />
    			<param name="LevelMin" value="TRACE" />
    		</filter>
    	</appender>
    
    	<!--将级别为DEBUG的信息输出到控制台 -->
    	<appender name="LOG.DEBUG" class="org.apache.log4j.DailyRollingFileAppender">
    		<param name="File" value="/zhaochao/logs/demo/debug.log" />
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d %p [%c] - %m%n" />
    		</layout>
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMin" value="DEBUG" />
    			<param name="LevelMax" value="DEBUG" />
    		</filter>
    	</appender>
    	<!--将级别为INFO的信息输出到控制台 -->
    	<appender name="LOG.INFO" class="org.apache.log4j.RollingFileAppender">
    		<param name="File" value="/zhaochao/logs/demo/info.log" />
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d %p [%c] - %m%n" />
    		</layout>
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMin" value="INFO" />
    			<param name="LevelMax" value="INFO" />
    		</filter>
    	</appender>
    	<!--将级别为WARN的信息输出到控制台 -->
    	<appender name="LOG.WARN" class="org.apache.log4j.DailyRollingFileAppender">
    		<param name="File" value="/zhaochao/logs/demo/warn.log" />
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d %p [%c] - %m%n" />
    		</layout>
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMin" value="WARN" />
    			<param name="LevelMax" value="WARN" />
    		</filter>
    	</appender>
    	<!--将级别为ERROR的信息输出到控制台 -->
    	<appender name="LOG.ERROR" class="org.apache.log4j.DailyRollingFileAppender">
    		<param name="File" value="/zhaochao/logs/demo/error.log" />
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d %p [%c] - %m%n" />
    		</layout>
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMin" value="ERROR" />
    			<param name="LevelMax" value="ERROR" />
    		</filter>
    	</appender>
    
    	<!--将级别为FATAL的信息输出到日志 -->
    	<appender name="LOG.FATAL" class="org.apache.log4j.DailyRollingFileAppender">
    		<param name="File" value="/zhaochao/logs/demo/fatal.log" />
    		<layout class="org.apache.log4j.PatternLayout">
    			<param name="ConversionPattern" value="%d %p [%c] - %m%n" />
    		</layout>
    		<filter class="org.apache.log4j.varia.LevelRangeFilter">
    			<param name="LevelMin" value="FATAL" />
    			<param name="LevelMax" value="FATAL" />
    		</filter>
    	</appender>
    
    	<root>
    		<priority value="INFO" />
    		<appender-ref ref="LOG.DEBUG" />
    		<appender-ref ref="LOG.INFO" />
    		<appender-ref ref="LOG.WARN" />
    		<appender-ref ref="LOG.ERROR" />
    		<appender-ref ref="LOG.FATAL" />
    		<appender-ref ref="LOG.CONSOLE" />
    	</root>
    
    </log4j:configuration>


    <?xml version="1.0" encoding="UTF-8"?>
    <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:mvc="http://www.springframework.org/schema/mvc"
    	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:p="http://www.springframework.org/schema/p"
    	xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
    		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
    		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
    		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
    		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"
    	default-autowire="byType">
    
    	<!-- Annotation Config -->
    	<context:annotation-config />
    	<!-- 扫描Service -->
    	<context:component-scan base-package="com.zhaochao.service" />
    	<!-- 数据源配置 -->
    	<bean id="dataSource-manager" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    		<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
    		<property name="url" value="jdbc:mysql://localhost:3306/dataSoruce?useUnicode=true&characterEncoding=utf-8"></property>
    		<property name="username" value="root"></property>
    		<property name="password" value="root"></property>
    		<!-- 配置初始化大小、最小、最大 -->
    		<property name="initialSize" value="5" />
    		<property name="minIdle" value="10" />
    		<property name="maxActive" value="10" />
    		<!-- 配置获取连接等待超时的时间 -->
    		<property name="maxWait" value="4000" />
    		<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
    		<property name="timeBetweenEvictionRunsMillis" value="60000" />
    		<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
    		<property name="minEvictableIdleTimeMillis" value="300000" />
    		<property name="validationQuery" value="SELECT 'x'" />
    		<property name="testWhileIdle" value="true" />
    		<property name="testOnBorrow" value="false" />
    		<property name="testOnReturn" value="false" />
    		<!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
    		<property name="poolPreparedStatements" value="true" />
    		<property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
    		<!-- 配置监控统计拦截的filters -->
    		<property name="filters" value="stat" />
    	</bean>
    
    	<!-- ***************事务配置************** -->
    	<tx:annotation-driven transaction-manager="transactionManager" />
    	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    		<property name="dataSource" ref="dataSource-manager" />
    	</bean>
    	
    	<!-- spring jdbc 模块 -->
    	<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
    		<property name="dataSource" ref="dataSource-manager" />
    	</bean>
    
    </beans>
    

    7.单元测试

    package com.test;
    
    import static org.junit.Assert.*;
    
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.test.context.ContextConfiguration;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
    
    import com.zhaochao.service.IAccountService;
    @RunWith(SpringJUnit4ClassRunner.class)
    @ContextConfiguration("classpath:spring-common.xml")
    public class TestMoney {
    
    	@Autowired(required=true)
    	private IAccountService accountService;
    	
    	@Test
    	public void test() {
    		accountService.giveMoney();
    	}
    
    }
    


  • 相关阅读:
    解决ssh或ftp下root用户认证失败问题
    setsockopt IP_ADD_MEMBERSHIP error!No such device的解决方案
    嵌入式Linux软件工程师面试题一
    00.嵌入式Linux开发环境搭建
    这个是豆瓣查书的api
    CentOS7.x安装MongoDB3.2.3教程
    Linux(Centos7)yum安装最新mysql
    解决npm速度慢的问题!!!
    windows下Gulp入门详细教程
    hibernate中hql查询
  • 原文地址:https://www.cnblogs.com/whzhaochao/p/5023407.html
Copyright © 2011-2022 走看看