博客
关于我
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学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
Mysql学习笔记 - 在Centos7环境下离线安装Mysql
查看>>
MySQL学习笔记十七:复制特性
查看>>
Mysql学习第一课-mysql的定义及sql语句
查看>>
mysql学号的字符长度_MYSQL--2
查看>>
mysql安全模式: sql_safe_updates
查看>>
mysql安装,卸载,连接
查看>>
MySQL安装之没有配置向导
查看>>
mysql安装出现 conflicts with mysql*的解决办法
查看>>
mysql安装卡在最后一步解决方案(附带万能安装方案)
查看>>
mysql安装和启动命令小结
查看>>