Spring框架 XML配置事务控制的步骤操作

目录
  • 基于 XML 的声明式事务控制
    • 1.环境搭建
    • 2.创建 spring 的配置文件并导入约束
    • 3.准备数据库表和实体类
    • 4.业务层接口与实现类
    • 5.数据访问层接口与实现类
    • 6.配置c3p0数据源/业务层/数据访问层
    • 7.配置事务管理器
    • 8.配置事务的通知
    • 9.配置 AOP 切入点表达式
    • 10.配置切入点表达式和事务通知的对应关系

基于 XML 的声明式事务控制

1.环境搭建

拷贝必要的 jar 包到工程的 lib 目录

2.创建 spring 的配置文件并导入约束

这里直接给出本次测试的全部XML配置,具体细节在后面依次介绍。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:context="http://www.springframework.org/schema/context"
	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.xsd
		http://www.springframework.org/schema/context
		http://www.springframework.org/schema/context/spring-context.xsd
		http://www.springframework.org/schema/aop
		http://www.springframework.org/schema/aop/spring-aop.xsd
		http://www.springframework.org/schema/tx
		http://www.springframework.org/schema/tx/spring-tx.xsd ">
	<!-- 配置连接池对象 -->
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="com.mysql.jdbc.Driver" />
		<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/mybase2" />
		<property name="user" value="root" />
		<property name="password" value="Hudie" />
	</bean>

	<!-- 配置JdbcTemplate模板对象 -->
	<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
		<property name="dataSource" ref="dataSource"></property>
	</bean>

	<!-- dao -->
	<bean id="userDao" class="com.gql.dao.UserDaoImp">
		<property name="jdbcTemplate" ref="jdbcTemplate"></property>
	</bean>
	<!-- service -->
	<bean id="userService" class="com.gql.service.UserServiceImp">
		<property name="userDao" ref="userDao"></property>
	</bean>

	<!-- 事务类/切面 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource"></property>
	</bean>

	<!--
		通知:
		1.告诉Spring容器采用哪种事务管理机制.
		2.告诉Spring容器目标方法采用什么样的事务处理策略.
	-->
	<tx:advice id="tx" transaction-manager="transactionManager">
		<tx:attributes>
				<!--
					name 规定目标方法
					isolation 事务隔离级别,默认是default
					propagation 传播机制,默认是REQUIREL
				-->
			<tx:method name="save" isolation="DEFAULT" propagation="REQUIRED" read-only="false" />
			<tx:method name="up*" isolation="DEFAULT" propagation="REQUIRED" read-only="false" />
			<tx:method name="de*" isolation="DEFAULT" propagation="REQUIRED" read-only="false" />
			<tx:method name="get*" isolation="DEFAULT" propagation="REQUIRED" read-only="true" />
		</tx:attributes>
	</tx:advice>
	<aop:config>
		<aop:pointcut expression="execution (* com.gql.service.UserServiceImp.*(..))" id="point" />
		<aop:advisor advice-ref="tx" pointcut-ref="point" />
	</aop:config>
</beans>

3.准备数据库表和实体类

user数据库表

create database mybase2;
USE mybase2;
CREATE TABLE `user` (
	`id` INT(10) NOT NULL AUTO_INCREMENT COMMENT '主键',
	`name` VARCHAR(20) NOT NULL DEFAULT '0',
	`age` INT(10) NOT NULL DEFAULT '0',
	PRIMARY KEY (`id`)
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB
;
INSERT INTO user values(NULL,'周冬雨',21);
INSERT INTO user values(NULL,'马冬梅',18);
INSERT INTO user values(NULL,'马西梅',19);

User实体类

package com.gql.entity;
import java.io.Serializable;
/**
 * 类说明:
 *		User实体类
 * @guoqianliang1998.
 */
public class User implements Serializable {
	/**
	 * 生成序列号
	 */
	private static final long serialVersionUID = -4492760954899814333L;
	private int id;
	private String name;
	private int age;

	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
}

4.业务层接口与实现类

业务层接口

package com.gql.service;
import java.util.List;
import com.gql.entity.User;
/**
 * 类说明:
 *		业务层接口
 * @guoqianliang1998.
 */
public interface UserService {
	void save(User user);
	void update(int id, User user);
	void delete(int id);
	User getUser(int id);
	List<User> getUserList(int[] ids);

	List<User> getUserList();
}

业务层实现类

package com.gql.service;
import java.util.List;
import com.gql.dao.UserDao;
import com.gql.entity.User;
/**
 * 类说明:
 *		业务层实现类
 * @guoqianliang1998.
 */
public class UserServiceImp implements UserService {
	private UserDao userDao;

	public void setUserDao(UserDao userDao) {
		this.userDao = userDao;
	}
	@Override
	public void save(User user) {
		userDao.save(user);
		int i = 1/0;
	}
	@Override
	public void update(int id, User user) {
		userDao.update(id, user);
	}
	@Override
	public void delete(int id) {
		userDao.delete(id);
	}
	@Override
	public User getUser(int id) {
		User user = userDao.getUser(id);
		return user;
	}
	@Override
	public List<User> getUserList(int[] ids) {
		List<User> userList = userDao.getUserList(ids);
		return userList;
	}
	@Override
	public List<User> getUserList() {
		List<User> list = userDao.getUserList();
		return list;
	}
}

5.数据访问层接口与实现类

数据访问层接口

package com.gql.dao;
import java.util.List;
import com.gql.entity.User;
/**
 * 类说明:
 * 		数据访问层接口
 * @guoqianliang1998.
 */
public interface UserDao {
	void save(User user);
	void update(int id, User user);
	void delete(int id);
	User getUser(int id);
	List<User> getUserList(int[] ids);

	List<User> getUserList();
}

数据访问层实现类

package com.gql.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import com.gql.RowMapper.UserRowMapper;
import com.gql.entity.User;
/**
 * 类说明:
 * 		数据访问层实现类
 * @guoqianliang1998.
 */
public class UserDaoImp implements UserDao {
	private JdbcTemplate jdbcTemplate;
	public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
		this.jdbcTemplate = jdbcTemplate;
	}
	@Override
	public void save(User user) {
		String sql = "INSERT INTO user values(NULL,?,?)";
		jdbcTemplate.update(sql, user.getName(), user.getAge());
	}
	@Override
	public void update(int id, User user) {
		String sql = "update user set name=?,age=? WHERE id = ?";
		jdbcTemplate.update(sql, user.getName(), user.getAge(), id);
	}
	@Override
	public void delete(int id) {
		String sql = "DELETE FROM user WHERE id = ?;";
		jdbcTemplate.update(sql, id);
	}
	@Override
	public User getUser(int id) {
		String sql = "select * from user where id = ?";
		User user = jdbcTemplate.queryForObject(sql, new RowMapper<User>() {
			@Override
			public User mapRow(ResultSet rs, int rowNum) throws SQLException {
				User user = new User();
				user.setId(rs.getInt(1));
				user.setName(rs.getString(2));
				user.setAge(rs.getInt(3));
				return user;
			}
		}, id);
		return user;
	}
	@Override
	public List<User> getUserList(int[] ids) {
		String sql = "select * from user where id in(:ids)";

		NamedParameterJdbcTemplate n = new NamedParameterJdbcTemplate(jdbcTemplate.getDataSource());
		Map<String,Object> paramMap = new HashMap<String,Object>();
		List list = new ArrayList();
		for (int i = 0; i < ids.length; i++) {
			list.add(ids[i]);
		}
		paramMap.put("ids", list);
		List<User> userList = n.query(sql, paramMap, new RowMapper<User>(){
			@Override
			public User mapRow(ResultSet rs, int rowNum) throws SQLException {
				User user = new User();
				user.setId(rs.getInt(1));
				user.setName(rs.getString(2));
				user.setAge(rs.getInt(3));
				return user;
			}
		});
		return userList;

//		第二种写法↓↓↓
//		StringBuilder sb = new StringBuilder();
//		sb.append("SELECT * FROM user WHERE id = ?");
//		for(int i=0;i<ids.length-1;i++){
//			sb.append(" or id = ?");
//		}
//		Integer[] in = new Integer[ids.length];
//		for(int i=0;i<ids.length;i++){
//			in[i] = ids[i];
//		}
//		Object[] args = in;
//		List<User> userList = jdbcTemplate.query(sb.toString(),args,new RowMapper() {
//
//			@Override
//			public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
//				User user = new User();
//				user.setId(rs.getInt(1));
//				user.setName(rs.getString(2));
//				user.setAge(rs.getInt(3));
//				return user;
//			}
//		});
//		return userList;
	}
	@Override
	public List<User> getUserList() {
		String sql = "select * from user";
		List<User> list = jdbcTemplate.query(sql, new UserRowMapper());
		return list;
	}
}

6.配置c3p0数据源/业务层/数据访问层

配置c3p0数据源

	<!-- 配置连接池对象 -->
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="com.mysql.jdbc.Driver" />
		<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/mybase2" />
		<property name="user" value="root" />
		<property name="password" value="Hudie" />
	</bean>
		<!-- 配置JdbcTemplate模板对象 -->
	<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
		<property name="dataSource" ref="dataSource"></property>
	</bean>

业务层

	<!-- service -->
	<bean id="userService" class="com.gql.service.UserServiceImp">
		<property name="userDao" ref="userDao"></property>
	</bean>

数据访问层

	<!-- dao -->
	<bean id="userDao" class="com.gql.dao.UserDaoImp">
		<property name="jdbcTemplate" ref="jdbcTemplate"></property>
	</bean>

7.配置事务管理器

	<!-- 事务管理器 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<!-- 注入 DataSource-->
		<property name="dataSource" ref="dataSource"></property>
	</bean>

8.配置事务的通知

事务的通知:

  • 配置事务的通知来引用事务管理器
  • 告诉Spring容器采用哪种事务管理机制.
  • 告诉Spring容器目标方法采用什么样的事务处理策略.
	<!--
		事务的通知:
		1.告诉Spring容器采用哪种事务管理机制.
		2.告诉Spring容器目标方法采用什么样的事务处理策略.
	-->
	<tx:advice id="tx" transaction-manager="transactionManager">
		<tx:attributes>
				<!--
					name 规定目标方法
					isolation 事务隔离级别,默认是default
					propagation 传播机制,默认是REQUIREL
				-->
			<tx:method name="save" isolation="DEFAULT" propagation="REQUIRED" read-only="false" />
		</tx:attributes>
	</tx:advice>

通知内配置事务的属性

属性 说明
read-only 是否是只读事务。默认 false,不只读。
isolation 指定事务的隔离级别。默认值是使用数据库的默认隔离级别。
propagation 指定事务的传播行为。
timeout 指定超时时间。默认值为:-1。永不超时。
rollback-for 用于指定一个异常,当执行产生该异常时,事务回滚。产生其他异常,事务不回滚。没有默认值,任何异常都回滚。
no-rollback-for 用于指定一个异常,当产生该异常时,事务不回滚,产生其他异常时,事务回
滚。没有默认值,任何异常都回滚。

9.配置 AOP 切入点表达式

 <!-- AOP切入点表达式 -->
 <aop:config>
  <aop:pointcut expression="execution (* com.gql.service.UserServiceImp.*(..))" id="point" />
  <!-- 切入点表达式和事务的对应关系 -->
  <aop:advisor advice-ref="tx" pointcut-ref="point" />
 </aop:config>

10.配置切入点表达式和事务通知的对应关系

 <!-- AOP切入点表达式 -->
 <aop:config>
  <aop:pointcut expression="execution (* com.gql.service.UserServiceImp.*(..))" id="point" />
  <!-- 切入点表达式和事务的对应关系 -->
  <aop:advisor advice-ref="tx" pointcut-ref="point" />
 </aop:config>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Spring中的事务操作、注解及XML配置详解

    事务 事务全称叫数据库事务,是数据库并发控制时的基本单位,它是一个操作集合,这些操作要么不执行,要么都执行,不可分割.例如我们的转账这个业务,就需要进行数据库事务的处理. 转账中至少会涉及到两条 SQL 语句: update Acoount set balance = balance - money where id = 'A'; update Acoount set balance = balance + money where id = 'B' 上面这两条 SQL 就可以要看成是一个事务,必

  • Spring SpringMVC,Spring整合MyBatis 事务配置的详细流程

    整合思路 (1)SSM是什么? Spring,SpringMVC,Mybastis (2)思路 搭建整合的环境,初始化环境 搭建Spring环境,配置完成并测试 (service层) 再使用Spring整合MyBatis框架,并测试(Dao层) 最后使用Spring整合SpringMVC框架,并测试(web层) SSM搭建环境 (1)数据库创建ssm (2)创建maven工程 (3)git (创建.gitignore来过滤不用提交的文件) (4)依赖框架 (5)log4j.properties

  • ssm整合之Spring整合MyBatis框架配置事务的详细教程

    ssm整合之Spring整合MyBatis框架配置事务 1.在applicationContext.xml修改代码如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance

  • spring基于注解配置实现事务控制操作

    目录 spring注解配置实现事务控制 1.导入相关依赖 2.创建spring配置类 3.创建JdbcConfig数据源配置类 4.创建TransactionConfig事务配置类 5.创建jdbcConfig.properties 6.使用事务注解 Spring注解方式的事务实现机制 1.事务的实现机制 AOP动态代理进行方法拦截 事务管理器进行事务提交或回滚 2.注解方式的事务使用注意事项 正确的设置 @Transactional 的 propagation 属性(熟知事务的传播特性) 正确

  • Spring框架 XML配置事务控制的步骤操作

    目录 基于 XML 的声明式事务控制 1.环境搭建 2.创建 spring 的配置文件并导入约束 3.准备数据库表和实体类 4.业务层接口与实现类 5.数据访问层接口与实现类 6.配置c3p0数据源/业务层/数据访问层 7.配置事务管理器 8.配置事务的通知 9.配置 AOP 切入点表达式 10.配置切入点表达式和事务通知的对应关系 基于 XML 的声明式事务控制 1.环境搭建 拷贝必要的 jar 包到工程的 lib 目录 2.创建 spring 的配置文件并导入约束 这里直接给出本次测试的全部

  • Spring框架 注解配置事务控制的流程

    目录 基于注解的事务控制 1.配置事务管理器 2.在业务层使用@Transactional 注解 3.开启 spring 对注解事务的支持 4.注解扫描器 Spring 注解事务实现机制 1.事务的实现机制 2.注解方式的事务使用注意事项 写在前面:虽然使用注解方式配置事务控制很简单,用起来也很爽,但是在每个方法前都加上@xxx形式的注解,显然并不美观,也不利于代码的规范与维护,所以XML的配置方式是才是重点. 基于注解的事务控制 基于注解配置事务控制,相较XML配置来说更加简单,但仍需要XML

  • Spring框架JdbcTemplate数据库事务管理完全注解方式

    目录 Spring JdbcTemplate事务注解 配置类方式配置 完全注解方式 一.创建配置类 二.测试注解方式的事务管理 Spring JdbcTemplate事务注解 配置类方式配置 在之前的操作中,相关的配置还是写在了 xml 配置文件中.现在,使用配置类的方式进行配置. <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework

  • Spring基于注解配置事务的属性

    本文实例为大家分享了Spring基于注解配置事务的属性,供大家参考,具体内容如下 一.事务属性概述 在Spring中,事务属性描述了事务策略如何应用到方法上,事务属性包含5个方面: ① 传播行为② 隔离级别③ 回滚策略④ 超时时间⑤ 是否只读 二.事务的传播行为属性## 1.当事务方法被另一个事务方法调用时,必须指定事务应该如何传播.例如,方法可能继续在现有的事务中允许,也可能开启一个新事务,并在自己的事务中运行.2.事务的传播行为可以由传播属性指定,Spring定义了7种类型的传播行为.其中最

  • java实现Spring在XML配置java类的方法

    1. 创建自己的bean文件:beans.xml <?xml version="1.0" encoding="UTF-8"?> <busi-beans> <beans> <bean id="SysHelloImpl" type="com.cxm.test.SysHello"> <desc>test</desc> <impl-class>com.

  • 详解Java的Spring框架中的事务管理方式

    数据库事务是被当作单个工作单元的操作序列.这些操作要么全部完成或全部不成功.事务管理是面向企业应用程序,以确保数据的完整性和一致性RDBMS中的重要组成部分.事务的概念可以用下面的描述为ACID四个关键属性来描述: 原子性: 一个事务应该被视为单个操作单元表示的操作的任一整个序列是成功的或不成功的. 一致性: 这代表了数据库的参照完整性,在桌等唯一主键的一致性 隔离性: 可能有很多事务处理相同的数据集的同时,每个事务都应由他人隔离,以防止数据损坏. 持久性: 一旦事务完成,本次事务的结果必须作出

  • spring的xml文件打开没有namespace等操作选项的解决方案

    目录 spring xml文件打开没有namespace等操作选项 第一步 第二步 第三步 spring suite tool 选择Namespace缺少mvc命名空间 spring xml文件打开没有namespace等操作选项 第一步 查看自己安装的eclipse的正确的版本号: 打开eclipse,点击help-->about eclipse IDE---->就可以看到你自己的eclipse对应的版本号 第二步 http://spring.io/tools3/sts/legacy到插件的

  • 在Java的Spring框架中配置Quartz的教程

    Spring中配置Quartz的过程: 1.导入JAR包 quartz需要的JAR包,已经包含在spring中,位置在spring解压后目录的 \lib\quartz 下的quartz-all-1.6.1.jar, 将其拷贝到工程 的 WEB-INF/lib 下就行了. 2.配置web.xml,让spring启动时加载quartz的配置文件 <?xml version="1.0" encoding="UTF-8"?> <web-app versio

  • 在Java的Spring框架的程序中使用JDBC API操作数据库

    同时与数据库使用普通的旧JDBC的工作,它变得繁琐写不必要的代码来处理异常,打开和关闭数据库连接等,但Spring的JDBC框架需要的所有低层次细节从打开连接,准备和执行SQL语句,过程异常,处理事务,最后关闭连接. 所以,你所要做的只是定义连接参数,并指定要执行的SQL语句,并做必要的工作,在每次迭代时从数据库中获取数据. Spring JDBC提供了一些方法和相应不同的类与数据库进行交互.我要采取经典和最流行的做法,利用JdbcTemplateclass框架.这是管理的所有数据库的通信和异常

随机推荐