Spring 事物管理

事物管理在应用程序中至关重要,它是一系列任务组成的工作单元,其中的所有任务必须同时执行,而且只有两种可能的执行结果,即全部成功和全部失败

编程式事物管理

利用 Transaction Template 实现 Spring 编程式事务管理

1、 在配置文件中声明事物管理器和 Transaction Template 

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<!--  配置数据源  -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost:3306/db_database24 </value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>914717</value>
</property>
</bean>

	
<!--  定义TransactionTemplate模板  -->
<bean id="transactionTemplate" class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="propagationBehaviorName">
<!--限定事物的传播行为规定当前方法必须运行在事务中,如果没有事务,则创建一个。一个新的事务和方法一同开始,随着方法的返回或抛出异常而终止-->
<value>PROPAGATION_REQUIRED</value>
</property>
</bean>
<!--  定义事务管理器  -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
<!--  为TransactionExample注入数据源 、事务管理器、TransactionTemplate模板 -->
<bean id="transactionExample" class="com.mr.transaction.TransactionExample">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="transactionTemplate">
<ref bean="transactionTemplate"/>
</property>
</bean>
</beans>

2、创建类 TransactionExample ,定义添加数据的方法,在方法中执行两次添加数据库操作并作用事务保护操作

package com.mr.transaction;

import java.sql.Connection;
import java.sql.Statement;

import javax.sql.DataSource;

import org.springframework.jdbc.datasource.DataSourceUtils;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.TransactionStatus;
import org.springframework.transaction.support.TransactionCallback;
import org.springframework.transaction.support.TransactionTemplate;

public class TransactionExample {
	DataSource dataSource;// 注入数据源
	PlatformTransactionManager transactionManager;// 注入事务管理器
	TransactionTemplate transactionTemplate;// 注入TransactionTemplate模板

	public DataSource getDataSource() {
		return dataSource;
	}

	public void setDataSource(DataSource dataSource) {
		this.dataSource = dataSource;
	}

	public PlatformTransactionManager getTransactionManager() {
		return transactionManager;
	}

	public void setTransactionManager(PlatformTransactionManager transactionManager) {
		this.transactionManager = transactionManager;
	}

	public TransactionTemplate getTransactionTemplate() {
		return transactionTemplate;
	}

	public void setTransactionTemplate(TransactionTemplate transactionTemplate) {
		this.transactionTemplate = transactionTemplate;
	}

	public void transactionOperation() {
		transactionTemplate.execute(new TransactionCallback() {
			public Object doInTransaction(TransactionStatus status) {
				Connection conn = DataSourceUtils.getConnection(dataSource);// 获得数据库连接
				try {
					Statement stmt = conn.createStatement();
					// 执行两次添加方法
					stmt.execute("insert into tb_user(name,age,sex) values('小强','26','男')");
					int a = 0;// 制造异常测试事务是否配置成功
					a = 9 / a;
					stmt.execute("insert into tb_user(name,age,sex) values('小红','22','女')");
					System.out.println("操作执行成功!");
				} catch (Exception e) {
					transactionManager.rollback(status);// 事务回滚
					System.out.println("操作执行失败,事务回滚!");
					System.out.println("原因:" + e.getMessage());
				}
				return null;
			}
		});
	}
}

3、创建主类

package com.mr.main;

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

import com.mr.transaction.TransactionExample;

public class Manager {


	public static void main(String[] args) {
		
		ApplicationContext factory = new ClassPathXmlApplicationContext("applicationContext.xml"); // 装载配置文件
		TransactionExample transactionExample = (TransactionExample) factory.getBean("transactionExample");// 获取TemplateExample
		transactionExample.transactionOperation();// 执行添加方法
	}
}

当程序出现错误时,运行结果:

 当程序正常运行时,运行结果:

 声明式事务管理

利用 TransactionProxyFactoryBean 实现 Spring 声明式事务管理

1、在配置文件中定义数据源 DataSource 和事务管理器,该管理器被注入到 TransactionProxyFactoryBean 中,设置代理对象和事务属性

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<!--  配置数据源  -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost:3306/db_database24 </value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>914717</value>
</property>
</bean>



<!--  定义事务管理器  -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
<!--  定义TransactionProxy  -->
<bean id="transactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager">
<ref local="transactionManager"/>
</property>
<property name="target">
<bean id="addDAO" class="com.mr.dao.AddDAO">
<property name="dataSource">
<ref local="dataSource"/>
</property>
</bean>
</property>
<property name="proxyTargetClass" value="true"/>
<property name="transactionAttributes">
<props>
<prop key="add*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
</beans>

2、编写操作数据库的 AddDAO 类,在该类的 addUser 方法中,执行了两次数据库插入操作。这个方法在配置中被定义为事务性方法,并指定了事务属性,所以方法中的所有数据库操作都被当作一个事务处理。

package com.mr.dao;

import org.springframework.jdbc.core.support.JdbcDaoSupport;

import com.mr.user.User;

public class AddDAO extends JdbcDaoSupport {
	// 添加用户的方法
	public void addUser(User user) {
		// 执行添加方法的sql语句
		String sql = "insert into huiyuan (name,age,sex) values('" + user.getName() + "','" + user.getAge() + "','"
				+ user.getSex() + "')";
		// 执行两次添加方法
		getJdbcTemplate().execute(sql);
		int a = 0;// 制造异常测试事务是否配置成功
		a = 9 / a;
		getJdbcTemplate().execute(sql);
	}
}

3、创建主类

package com.mr.main;

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

import com.mr.dao.AddDAO;
import com.mr.user.User;

public class Manager {


	public static void main(String[] args) {
		nsactionExample.transactionOperation();// 执行添加方法
		 */
		ApplicationContext factory = new ClassPathXmlApplicationContext("applicationContext.xml"); // 装载配置文件
		AddDAO addDAO = (AddDAO) factory.getBean("transactionProxy");// 获取AddDAO
		User user = new User();// 实例化User实体对象
		user.setName("明日");// 设置姓名
		user.setAge(30);// 设置年龄
		user.setSex("男");// 设置性别
		addDAO.addUser(user);// 执行数据库添加方法
	}
}

程序出现错误时,运行结果:

 程序正确时,运行结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值