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

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

spring中基于xml的声明式事务控制配置步骤:

  1. 配置事务管理器。
  2. 配置事务的通知:
    • 此时我们需要导入事务的约束,同时也需要aop的。
    • 使用tx:advice标签配置事务通知。属性:id:给事务通知起一个唯一标识。transaction-manager:给事务通知提供一个事务管理器引用。
  3. 配置aop中的通用切入点表达式。
  4. 建立事务通知和切入点表达式的对应关系。
  5. 配置事务的属性。在事务的通知tx:advice标签的内部。
    • isolation:用于指定事务的隔离级别。默认值是DEFAULT,表示使用数据库的隔离级别。
    • propagation:用于指定事务的传播行为,默认值是REQUIRED,表示一定会有事务,增删改的选择。查询方法可以选择SUPPORTS。
    • read-only:用于指定事务是否只读,只有查询方法才能设置为true。默认值是false,表示读写。
    • timeout:用于指定事务的超时时间,默认值是-1,表示永不超时。如果指定了数值,以秒为单位。
    • rollback-for:用于指定一个异常,当产生该异常时事务回滚,产生其他异常时不回滚,没有默认值,表示任何异常都回滚。
    • no-rollback-for:用于指定一个异常,当产生该异常时,事务不回滚,产生其他异常时,事务回滚。没有默认值,表示任何异常都回滚。

示例:

pom.xml

4.0.0
com.qublog
spring04_tx_xml
1.0-SNAPSHOT
jar
org.springframework
spring-context
5.0.2.RELEASE
org.springframework
spring-jdbc
5.0.2.RELEASE
org.springframework
spring-tx
5.0.2.RELEASE
org.springframework
spring-test
5.0.2.RELEASE
mysql
mysql-connector-java
8.0.16
org.aspectj
aspectjweaver
1.8.7
junit
junit
4.12

Account类:

package com.qublog.domain;import java.io.Serializable;public class Account implements Serializable {       private Integer id;    private String name;    private Float money;    public Integer getId() {           return id;    }    public void setId(Integer id) {           this.id = id;    }    public String getName() {           return name;    }    public void setName(String name) {           this.name = name;    }    public Float getMoney() {           return money;    }    public void setMoney(Float money) {           this.money = money;    }    @Override    public String toString() {           return "Account{" +                "id=" + id +                ", name='" + name + '\'' +                ", money=" + money +                '}';    }}

AccountDao接口:

package com.qublog.dao;import com.qublog.domain.Account;//账户的持久层接口public interface AccountDao {       //根据id查询账户    Account findAccountById(Integer id);    //根据name查询账户    Account findAccountByName(String name);    //更新账户    void updateAccount(Account account);}

AccountDaoImpl类:

package com.qublog.dao.impl;import com.qublog.dao.AccountDao;import com.qublog.domain.Account;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.jdbc.core.support.JdbcDaoSupport;import java.util.List;public class AccountDaoImpl extends JdbcDaoSupport implements AccountDao {       public Account findAccountById(Integer id) {           List
accounts = getJdbcTemplate().query("select * from account where id=?",new BeanPropertyRowMapper
(Account.class),id); return accounts.isEmpty()?null:accounts.get(0); } public Account findAccountByName(String name) { List
accounts = getJdbcTemplate().query("select * from account where name=?",new BeanPropertyRowMapper
(Account.class),name); if (accounts.isEmpty()) { return null; } if (accounts.size()>1) { throw new RuntimeException("结果集不唯一"); } return accounts.get(0); } public void updateAccount(Account account) { getJdbcTemplate().update("update account set name=?,money=? where id=?",account.getName(),account.getMoney(),account.getId()); }}

AccountService接口:

package com.qublog.service;import com.qublog.domain.Account;//账户的业务层接口public interface AccountService {       //根据id查询账户信息    Account findAccountById(Integer id);    //转账    void transfer(String source, String target, Float money);}

AccountServiceImpl类:

package com.qublog.service.impl;import com.qublog.dao.AccountDao;import com.qublog.domain.Account;import com.qublog.service.AccountService;public class AccountServiceImpl implements AccountService {       private AccountDao accountDao;    public void setAccountDao(AccountDao accountDao) {           this.accountDao = accountDao;    }    public Account findAccountById(Integer id) {           return accountDao.findAccountById(id);    }    public void transfer(String sourceName, String targetName, Float money) {           System.out.println("transfer...");        //根据名称查询转出账户        Account source = accountDao.findAccountByName(sourceName);        //根据名称查询转入账户        Account target = accountDao.findAccountByName(targetName);        //转出账户减钱        source.setMoney(source.getMoney()-money);        //转入账户加钱        target.setMoney(target.getMoney()+money);        //更新转出账户        accountDao.updateAccount(source);        int i=1/0;        //更新转入账户        accountDao.updateAccount(target);    }}

bean.xml

AccountServiceTest类:

package com.qublog.test;import com.qublog.service.AccountService;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.test.context.ContextConfiguration;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;//使用Junit单元测试,测试我们的配置@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations = "classpath:bean.xml")public class AccountServiceTest {       @Autowired    private AccountService as;    @Test    public void testTransfer() {           as.transfer("aaa","bbb",100f);    }}

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

你可能感兴趣的文章
Mysql索引(1):索引概述
查看>>
Mysql索引(2):索引结构
查看>>
Mysql索引(3):索引分类
查看>>
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql练习语句
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给root开启远程访问权限,修改root密码
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql编写存储过程
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql联合索引 where_mysql联合索引与Where子句优化浅析
查看>>
mysql联合索引的最左前缀匹配原则
查看>>
MySQL聚簇索引
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>
Mysql自增id理解
查看>>