AOP数据库操作回滚配置

<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
		http://www.springframework.org/schema/beans/spring-beans-3.2.xsd 
		http://www.springframework.org/schema/mvc 
		http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd 
		http://www.springframework.org/schema/context 
		http://www.springframework.org/schema/context/spring-context-3.2.xsd 
		http://www.springframework.org/schema/aop 
		http://www.springframework.org/schema/aop/spring-aop-3.2.xsd 
		http://www.springframework.org/schema/tx 
		http://www.springframework.org/schema/tx/spring-tx-3.2.xsd ">


	 <!-- 使用声明式事务配置,可以有效规范代码 -->
	 
	 <!-- 事务管理器 -->
	 <bean id="transactionManager" 
	 		class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
	 	<property name="dataSource" ref="dataSource"/>
	 </bean>
	 
	 <!-- 通知 事务回滚 -->
	 <!-- readonly是设置操作权限为只读,一般用于查询的方法,优化作用 -->
	 <!-- 注解用 rollback-for) 定义当遇到Exception异常 时 回滚 -->
	 <!-- REQUIRED:如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择 -->
	 <!-- REQUIRES_NEW:新建事务,如果当前存在事务,把当前事务挂起 -->
	 <!-- SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行 -->
	 <tx:advice id="txAdvice" transaction-manager="transactionManager">
	 	<tx:attributes>
	 		<tx:method name="save*" propagation="REQUIRED" rollback-for="Exception"/>
	 		<tx:method name="insert*" propagation="REQUIRED" rollback-for="Exception"/>
	 		<tx:method name="update*" propagation="REQUIRED" rollback-for="Exception"/>
	 		<tx:method name="delete*" propagation="REQUIRED" rollback-for="Exception"/>
	 		<tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
	 		<tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
	 		<tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
			<tx:method name="log" propagation="REQUIRES_NEW" rollback-for="Exception"/><!-- 记录日志专用,在主事务回滚后日志仍记录成功 -->
	 	</tx:attributes>
	 </tx:advice>
	 
	 <!-- aop -->
	 <aop:config>
		<aop:pointcut id="serviceMethod" expression="execution(* cn.itcast.ssm.service.*Impl.*.*(..))" />
	 	<aop:advisor pointcut-ref="serviceMethod" advice-ref="txAdvice" />
	 </aop:config>
	
</beans>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AOP静态代理连接数据库的过程如下: 1. 首先,创建一个连接管理类(ConnectionMange),该类负责管理数据库连接和事务的开启、提交、回滚以及释放。\[3\] 2. 在连接管理类中,通过静态代理的方式,创建一个代理类(ConnectionMangeProxy),该代理类实现了与连接管理类相同的接口,并在方法执行前后添加了额外的逻辑,比如在方法执行前开启事务,在方法执行后提交事务或回滚事务。这样,通过代理类来管理数据库连接,可以在不修改原有代码的情况下,实现对数据库连接的控制和管理。\[1\] 3. 在AOP中,可以使用Spring框架提供的原生接口方式或注解配置方式来实现代理。原生接口方式需要定义切面类(Aspect),在切面类中定义切点(Pointcut)和通知(Advice),通过配置将切面类与目标类关联起来,从而实现对目标类方法的代理。注解配置方式则可以通过在目标类的方法上添加注解来实现代理。\[2\] 4. 在代理类中,可以通过连接管理类的实例来获取数据库连接,并在方法执行前后进行相应的操作,比如在方法执行前开启事务,在方法执行后提交事务或回滚事务。这样,就实现了通过静态代理的方式来连接数据库并进行事务管理。\[1\] 综上所述,AOP静态代理连接数据库的过程是通过创建代理类来管理数据库连接,并在方法执行前后添加额外的逻辑来实现事务管理。 #### 引用[.reference_title] - *1* [spring复习04,静态代理动态代理,AOP](https://blog.csdn.net/m0_63622279/article/details/128082960)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [静态代理、JDK与CGLIB动态代理、AOP+IoC原理](https://blog.csdn.net/u013128651/article/details/80194496)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java代理——静态代理、单接口动态代理、多接口动态代理、AOP编程](https://blog.csdn.net/lmlzww/article/details/104684088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值