首页 > 编程语言 > 详细

Spring事务管理

时间:2015-06-20 20:53:52      阅读:277      评论:0      收藏:0      [点我收藏+]

概念

技术分享

流程

技术分享

spring声明式事务处理的步骤

技术分享

技术分享

package cn.itcast.spring.jdbc.transaction.bean;

public class Person {
	private Long pid;
	private String pname;
	private String psex;
	public Long getPid() {
		return pid;
	}
	public void setPid(Long pid) {
		this.pid = pid;
	}
	public String getPname() {
		return pname;
	}
	public void setPname(String pname) {
		this.pname = pname;
	}
	public String getPsex() {
		return psex;
	}
	public void setPsex(String psex) {
		this.psex = psex;
	}
}
异常类

package cn.itcast.spring.jdbc.transaction.exception;

public class MyException {
	public void myException(Throwable ex){
		System.out.println(ex.getMessage());
	}
}



package cn.itcast.spring.jdbc.transaction.sh.dao;

import java.util.List;

import cn.itcast.spring.jdbc.transaction.bean.Person;

public interface PersonDao {
	public void savePerson();
	public List<Person> getPerson();
}



package cn.itcast.spring.jdbc.transaction.sh.dao;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.support.JdbcDaoSupport;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.support.AbstractPlatformTransactionManager;

import cn.itcast.spring.jdbc.transaction.bean.Person;

public class PersonDaoImpl extends JdbcDaoSupport implements PersonDao{

	@Override
	public List<Person> getPerson() {
		// TODO Auto-generated method stub
		return this.getJdbcTemplate().query("select * from person", new RowMapper() {
			
			@Override
			public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
				// TODO Auto-generated method stub
				Person person = new Person();
				person.setPid(rs.getLong("pid"));
				person.setPname(rs.getString("pname"));
				person.setPsex(rs.getString("psex"));
				return person;
			}
		});
	}

	@Override
	public void savePerson() {
		// TODO Auto-generated method stub
		this.getJdbcTemplate().update("insert into person(pname,psex) values(‘a‘,‘a‘)");
	}
	
}



package cn.itcast.spring.jdbc.transaction.sh.service;

import java.util.List;

import cn.itcast.spring.jdbc.transaction.bean.Person;

public interface PersonService {
	public void savePerson();
	public List<Person> getPerson();
}



package cn.itcast.spring.jdbc.transaction.sh.service;

import java.util.List;

import org.springframework.transaction.PlatformTransactionManager;

import cn.itcast.spring.jdbc.transaction.bean.Person;
import cn.itcast.spring.jdbc.transaction.sh.dao.PersonDao;

public class PersonServiceImpl implements PersonService{
	private PersonDao personDao;

	public PersonDao getPersonDao() {
		return personDao;
	}

	public void setPersonDao(PersonDao personDao) {
		this.personDao = personDao;
	}

	@Override
	public List<Person> getPerson() {
		// TODO Auto-generated method stub
		return this.personDao.getPerson();
	}

	@Override
	public void savePerson() {
		// TODO Auto-generated method stub
		this.personDao.savePerson();
		int a = 1/0;
	}
	
}



package cn.itcast.spring.jdbc.transaction.test;

import javax.sql.DataSource;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import cn.itcast.spring.jdbc.transaction.sh.service.PersonService;

public class TransactionTest {
	public static ApplicationContext context;
	static{
		context = new ClassPathXmlApplicationContext("cn/itcast/spring/jdbc/transaction/config/applicationContext.xml");
	}
	@Test
	public void testDataSource(){
		DataSource dataSource = (DataSource)context.getBean("dataSource");
		System.out.println(dataSource);
	}
	
	@Test
	public void testPesonDao(){
		context.getBean("personDao");
	}
	
	@Test
	public void testPersonService(){
		PersonService personService = (PersonService)context.getBean("personService");
		personService.savePerson();
	}
}



<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
		http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
		http://www.springframework.org/schema/aop 
		http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
		http://www.springframework.org/schema/tx 
		http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">

	<bean
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="locations">
			<value>classpath:jdbc.properties</value>
		</property>
	</bean>

	<bean id="dataSource" destroy-method="close"
		class="org.apache.commons.dbcp.BasicDataSource">
		<property name="driverClassName" value="${jdbc.driverClassName}" />
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />
	</bean>

	<bean id="personDao" class="cn.itcast.spring.jdbc.transaction.sh.dao.PersonDaoImpl">
		<property name="dataSource">
			<ref bean="dataSource" />
		</property>
	</bean>

	<bean id="personService"
		class="cn.itcast.spring.jdbc.transaction.sh.service.PersonServiceImpl">
		<property name="personDao">
			<ref bean="personDao" />
		</property>
	</bean>

	<bean id="myException" class="cn.itcast.spring.jdbc.transaction.
	exception.MyException"></bean>
	<!-- (2)使用事务管理器,spring提供的类 -->
	<bean id="transactionManager"
		class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource">
			<ref bean="dataSource" />
		</property>
	</bean>
	<!--
		通知 1、告诉spring容器,采用什么样的方法处理事务 
			<bean id="transactionManager">
			
		2、告诉spring容器,对那些方法是用事务以及目标方法应该采用什么样的事务处理策略
			这一行就体现了声明式事务
			<tx:method name="save*" read-only="false" />
		
		事务肯定不能自己来写,这样的话就相当于程序猿还是要知道事务,还是要知道类和方法,还是得具体操作
		而在这里,程序猿只是负责声明一些而已
	-->
	<tx:advice id="tx" transaction-manager="transactionManager">
		<tx:attributes>
			<!--
				name规定方法  对save开头的方法进行事务管理
				isolation 默认值为DEFAULT  隔离机制,默认不改,所以可填可不填
				propagation 传播机制 REQUIRED  99%用required
				
				read-only false是读写事务,true是只读事务
				应该spring容器使用的session肯定是和程序猿使用的是同一个,那么spring容器就只能获取当前线程的session来使用
				而使用当前线程session进行操作的前提是所有CRUD必需在是事务下运行,所以就没有说有没有事务的区分
				只有只读或者可读写的区分
			-->
			<tx:method name="save*" read-only="false" />
		</tx:attributes>
	</tx:advice>

	<aop:config>
		<aop:pointcut
			expression="execution(* cn.itcast.spring.jdbc.transaction.sh.service.*.*(..))"
			id="perform" />
			<!-- 把事务加在切片中 -->
		<aop:advisor advice-ref="tx" pointcut-ref="perform" />
		
		<aop:aspect ref="myException">
			<aop:after-throwing method="myException"
				pointcut-ref="perform" throwing="ex" />
		</aop:aspect>
	</aop:config>
</beans>



Spring事务管理

原文:http://my.oschina.net/u/2356176/blog/469146

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!