spring aop 切面程式設計控制管理事務
1 一個業務邏輯方法中需要有操作插入兩張表記錄相互關聯依賴資料,
2 要保證兩張表要麼都插入成功要麼都插入失敗,
3 否則只成功插入任何一張表都是毫無意義的垃圾資料
本人想到spring AOP 事務管理能支援此業務需求功能,
具體配置如下經驗證:
1 DAO介面定義顯示丟擲異常
2 產生異常處catch時候 { throw new runtimeException} 這個是spring預設回滾的異常
<!--aop-->配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:security="http://www.springframework.org/schema/security"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">
<!-- transaction -->
<tx:annotation-driven transaction-manager="transactionManager" />
<bean name="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="create*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="remove*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="add*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="save*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="delete*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="update*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="insert*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="log*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="next*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="*" read-only="true" />
<tx:method name="do*" propagation="REQUIRED"
rollback-for="java.lang.Exception" />
<tx:method name="*" read-only="true" />
</tx:attributes>
</tx:advice>
<aop:config>
<aop:advisor pointcut="execution(* com.saic.grape.dao.impl..*.*(..))"
advice-ref="txAdvice" order="1" />
<aop:advisor pointcut="execution(* com.saic.grape.dop.dao.impl..*.*(..))"
advice-ref="txAdvice" order="2" />
</aop:config>
</beans>
<!--DAO操作-->
package com.saic.grape.dao;
import java.util.List;
import java.util.Map;
import com.saic.grape.entity.City;
/**
*
* @author xxxx
* @version 1.0
* @date
*
*/
public interface CityDAO {
/**
* 同時插入2張表,寫到事務控制範圍內,保證插入時候同時成功同時失敗,顯示丟擲異常
* @param map
* @return
* @throws Exception
*/
public int createTable(Map map) throws Exception;
}
package com.saic.grape.dao.impl;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Repository;
import com.saic.grape.base.dao.CommonBaseDao;
import com.saic.grape.dao.CityDAO;
import com.saic.grape.entity.City;
/**
* 城市介面實現類
*
* @version 1.0
* @date 2014-1-20
*
*/
@Repository("cityDAO")
public class CityDAOImpl extends CommonBaseDao<City, String> implements CityDAO {
private static final String nameSpace = "com.saic.grape.dao.CityDAO.";
@Override
public int createTable(Map map) throws Exception {
// TODO Auto-generated method stub
int re1= super.getSqlSession().insert(nameSpace + "createTable1", map);
int re2= super.getSqlSession().insert(nameSpace + "createTable2", map);
return re1+re2;
}
}
<!--controller-->
@Controller
@RequestMapping("/home/city")
public class CityController {
private Log logger = LogFactory.getLog(CityController.class);
@Resource
private CityDAO cityDAO;
/**
* 同時插入兩條記錄,如果一張表操作失敗,另外一張表也失敗
* @throws Exception
*/
@RequestMapping("/getAddress/0")
@ResponseBody
public Object getAddress(@RequestBody Map<String, Object> params) {
try {
cityDAO.createTable(params);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
相關文章
- Spring AOP——Spring 中面向切面程式設計Spring程式設計
- Spring之AOP面向切面程式設計Spring程式設計
- Spring AOP(面向切面程式設計)是什麼?Spring程式設計
- AOP(面向切面程式設計)程式設計
- AOP 面向切面程式設計程式設計
- Spring 面向切面程式設計AOP 詳細講解Spring程式設計
- 手寫Spring---AOP面向切面程式設計(4)Spring程式設計
- 手寫Spring---AOP面向切面程式設計(3)Spring程式設計
- Spring系列:基於Spring-AOP和Spring-Aspects實現AOP切面程式設計Spring程式設計
- AOP--面向切面程式設計程式設計
- Spring Boot實戰系列(3)AOP面向切面程式設計Spring Boot程式設計
- Day67 Spring AOP(面向切面程式設計) 和代理設計模式Spring程式設計設計模式
- 設計模式之面向切面程式設計AOP設計模式程式設計
- 前端js面向切面程式設計(AOP)前端JS程式設計
- Spring框架系列(4) - 深入淺出Spring核心之面向切面程式設計(AOP)Spring框架程式設計
- Spring之切面程式設計Spring程式設計
- 前端解讀面向切面程式設計(AOP)前端程式設計
- 01.AOP(AspectOrientatedProgramming面向切面程式設計)程式設計
- aop面向切面程式設計的實現程式設計
- Java中的面向切面程式設計(AOP)Java程式設計
- Spring 面向切面AOPSpring
- Spring AOP:面向切面程式設計的核心概念與實際應用Spring程式設計
- (系列七).net8 Aop切面程式設計程式設計
- JAVA_動態代理AOP切面程式設計Java程式設計
- Spring-AOP(面向切面)Spring
- 四、Spring-面向切面程式設計Spring程式設計
- 從原始碼入手,一文帶你讀懂Spring AOP面向切面程式設計原始碼Spring程式設計
- 面向切面程式設計 ( Aspect Oriented Programming with Spring )程式設計Spring
- Spring 面向方面程式設計 AOPSpring程式設計
- JS實現AOP 面向切面程式設計 (裝飾者模式)JS程式設計模式
- Spring IoC、面向切面程式設計、事務管理等Spring基本概念詳解Spring程式設計
- Spring理論基礎-面向切面程式設計Spring程式設計
- spring AOP 程式設計式應用Spring程式設計
- Util應用框架基礎(三) - 面向切面程式設計(AspectCore AOP)框架程式設計
- .NET Core 實現動態代理做AOP(面向切面程式設計)程式設計
- 程式設計思想 面向切面程式設計程式設計
- 基於SpringBoot AOP面向切面程式設計實現Redis分散式鎖Spring Boot程式設計Redis分散式
- 深入學習Spring框架(三)- AOP面向切面Spring框架
- Spring AOP AspectJ 切面表示式高階用法Spring