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

你可能感兴趣的文章
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>