博客
关于我
Spring中基于XML的声明式事务控制
阅读量:686 次
发布时间:2019-03-17

本文共 2869 字,大约阅读时间需要 9 分钟。

Spring中基于XML的声明式事务控制配置详细指南

在Spring框架中,基于XML 的声明式事务控制是一个体现Spring强大配置能力的重要特点。以下将详细介绍如何在Spring应用中配置基于XML的声明式事务控制。

1. 配置事务管理器

首先,需要在项目的Spring配置文件中添加一个配置bean,用于创建事务管理器。以下是一个典型的配置示例:

这里,DataSourceTransactionManager需要一个数据源作为决策器。数据源通常使用spring:jdbc中的DriverManagerDataSource配置。

2. 配置事务的通知

接下来,需要定义一个通用的事务通知,其作用是捕捉方法前后进行事务开始和提交、回滚操作。可以参考以下配置:

此外,还可以根据具体需求添加事务的隔离级别、超时设置等属性:

3. 配置切入点表达式

在Spring AOP中,需要定义一个通用的切入点表达式,以便为特定的方法或类方法创建事务通知。例如:

这里,execution(* com.qublog.service.impl.*.*(..)) 定义了一个切入点,表示所有在com.qublog.service.impl包下定义的方法都会被Spring的AOP拦截并应用事务通知。

4. 业务逻辑类与事务集成

在业务逻辑实现类中,通常会在需要事务支持的方法上使用事务注解。例如:

@Repositorypublic class AccountServiceImpl implements AccountService {    // 用@Autowired注入数据源    private DataSource dataSource;    // 已经注入的事务管理器    private TransactionManager transactionManager;    public void transfer(String sourceName, String targetName, Float money) throws Exception {        System.out.println("开始转账...");                // 获取转出账户        Account sourceAccount = findAccountByName(sourceName);        // 获取转入账户        Account targetAccount = findAccountByName(targetName);        // 修改转出账户金额        sourceAccount.setMoney(sourceAccount.getMoney() - money);        // 修改转入账户金额        targetAccount.setMoney(targetAccount.getMoney() + money);        // 提交事务        transactionManager.beginTransaction();                try {            AccountDaoume updateAccount(sourceAccount);            System.out.println("更新转出账户成功...");                        AccountDaoume updateAccount(targetAccount);            System.out.println("更新转入账户成功...");        } catch (Exception e) {            System.out.println("事务回滚...");            transactionManager.rollback();            throw e;        } finally {            transactionManagercommit();        }    }}

5. 数据源配置

确保在bean.xml中已正确配置数据源。以下是一个常用的配置示例:

6. 完整示例配置(bean.xml

以下是一个简化的bean.xml示例,包含了上述配置:

7. 测试类

测试类可以使用Spring Boot测试框架进行单元测试。例如:

@RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest@ContextConfiguration(locations = "classpath:bean.xml")public class AccountServiceTest {    @Autowired    private AccountService accountService;    @Autowired    private ApplicationContext applicationContext;    @Test    public void testTransfer() {        accountService.transfer("aaa", "bbb", 100f);        System.out.println("测试通过!");    }    @Test    public void testFindByname() {        Account account = accountService.findAccountById(1);        System.out.println(account);    }}

以上配置和相关代码,便利于在Spring应用中实现基于XML的声明式事务控制。

转载地址:http://jfchz.baihongyu.com/

你可能感兴趣的文章
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>