博客
关于我
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/

你可能感兴趣的文章
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>