当前位置:首页 > 开发 > 系统架构 > 架构 > 正文

Spring Mybatis独立事务配置

发表于: 2015-07-13   作者:toknowme   来源:转载   浏览:
摘要: 在项目中有很多地方会使用到独立事务,下面以获取主键为例   (1)修改配置文件spring-mybatis.xml  <!-- 开启事务支持 -->  <tx:annotation-driven transaction-manager="transactionManager" />   &n

在项目中有很多地方会使用到独立事务,下面以获取主键为例

 
(1)修改配置文件spring-mybatis.xml
 <!-- 开启事务支持 -->
 <tx:annotation-driven transaction-manager="transactionManager" />
 
 <!-- 拦截器方式配置事务 -->
 <!-- 定义service事务通知-->
 <tx:advice id="txAdvice" transaction-manager="transactionManager">
  <!-- 定义方法的过滤规则 -->
  <tx:attributes>
   <tx:method name="save*" propagation="REQUIRED" />
   <tx:method name="add*" propagation="REQUIRED" />
   <tx:method name="create*" propagation="REQUIRED" />
   <tx:method name="insert*" propagation="REQUIRED" />
   <tx:method name="update*" propagation="REQUIRED" />
   <tx:method name="merge*" propagation="REQUIRED" />
   <tx:method name="del*" propagation="REQUIRED" />
   <tx:method name="remove*" propagation="REQUIRED" />
   <tx:method name="put*" propagation="REQUIRED" />
   
   <tx:method name="get*" propagation="SUPPORTS" read-only="true" />
   <tx:method name="count*" propagation="SUPPORTS" read-only="true" />
   <tx:method name="find*" propagation="SUPPORTS" read-only="true" />
   <tx:method name="list*" propagation="SUPPORTS" read-only="true" />
   <tx:method name="*" propagation="SUPPORTS" read-only="true" />
   
   <!-- 获取主键开启独立事务 -->
   <tx:method name="getPKId" propagation="REQUIRES_NEW" />
  </tx:attributes>
 </tx:advice>  
 
 <!--AOP配置  -->
 <aop:config proxy-target-class="true">
  <!-- 适配切入点 和 事务的通知 -->
  <aop:pointcut id="txPointcut"
   expression="execution(* *..*SVImpl.*(..))" />
  <aop:advisor pointcut-ref="txPointcut" advice-ref="txAdvice" />
 </aop:config>
 
(2)服务层新增接口和方法
 
 
新增接口
ICommonSV
    新增方法
    public long getPKId(String tableName) throws Exception;
 
 
新增实现类
CommonSVImpl
    新增方法
    public long getPKId(String tableName) {
  long seq = -1;
  StringBuilder sb = new StringBuilder();
  sb.append(" SELECT ");
  sb.append(tableName).append("$SEQ.NEXTVAL SEQ ");
  sb.append(" FROM DUAL ");
  Map map = new HashMap();
  try {
   map = executeQuerySql(sb.toString()).get(0);
  } catch (Exception e) {
   throw new ZCrmException("["+tableName+"]获取主键失败:"+e.getMessage());
  }
  seq = Long.parseLong(map.get("SEQ").toString());
  log.info(tableName+"$SEQ:"+seq);
  return seq;
 }
 
 
@Autowired
 private ICommonDAO ICommonDAO;
 
 private synchronized List<Map> executeQuerySql(String sql) throws Exception {
  List<Map> o = null;
    o = ICommonDAO.executeQuerySql(new SQLAdapter(sql)); 
  return o;
 }
 

Spring Mybatis独立事务配置

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
Spring + mvc,Mybatis整合 (含事务配置,分页功能) 环境 WIN8 , Eclipse (Juno) , Maven 3.0.4 ,
一. 简介 本文将会使用spring整合mybatis, 并添加事务管理, 以此为记, 方便以后查阅。 二. 例子 1.
原文地址:Spring Transaction + MyBatis SqlSession事务管理机制研究学习 线上的系统中,使用的是S
事务配置 首先在/WEB-INF/applicationContext.xml添加以下内容: <!-- 配置事务管理器 --> &l
环境配置 项目使用SSH架构,现在要添加Spring事务管理功能,针对当前环境,只需要添加Spring 2.0 AO
转载出处:http://www.blogjava.net/liudecai/archive/2009/04/08/264467.html 非常感谢有人总结出
Spring配置文件中关于事务配置总是由三个组成部分,分别是DataSource、TransactionManager和代理机
根据代理机制不同,有以下几种配置方式: 先定义一个DAO接口及实现类: Java代码 public interface I
lygle 写道 根据代理机制不同,有以下几种配置方式: 先定义一个DAO接口及实现类: public interface
转载出处:http://www.blogjava.net/liudecai/archive/2009/04/08/264467.html 非常感谢有人总结出
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号