博客
关于我
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数据库中的数据如何加密呢?mysql8.0自带新特性
查看>>
MySQL数据库优化
查看>>
Mysql数据库函数contac_函数:函数删除操作语法&使用例——《mysql 从入门到内卷再到入土》...
查看>>
mysql数据库命令备份还原
查看>>
mysql数据库基础教程
查看>>
MySQL数据库备份
查看>>
mysql数据库备份与恢复
查看>>
MySQL数据库备份实战
查看>>
Mysql数据库备份的问题:mysqldump: Got error: 1049: Unknown_无需整理
查看>>
mysql数据库如何重置密码是多少钱_MySQL数据库忘记root密码如何重置修改
查看>>
MySQL数据库安装配置与常用命令
查看>>
MySQL数据库实现主从同步数据
查看>>
mysql数据库导入导出_windows系统以及linux系统下的操作---linux工作笔记042
查看>>
mysql数据库导出导入
查看>>
MySQL数据库工具类之——DataTable批量加入MySQL数据库(Net版)
查看>>
mysql数据库常用命令
查看>>
MySQL数据库必会的增删查改操作(CRUD)
查看>>
MySQL数据库性能分析与调优实践
查看>>
mysql数据库扫盲,你真的知道什么是数据库嘛
查看>>
mysql数据库批量插入数据shell脚本实现
查看>>