spring整合JDBC+spring aop事务

1.spring整合JDBC

    spring中提供了一个可以操作数据库的对象,对象封装了JDBC技术。

    JDBCTemplate:JDBC模板对象。与DBUtils中的QueryRunner非常相似。

    JDBCDaoSupport:根据连接池创建JDBC模板。

读取properties配置:(替代将DataSource注入到容器中)

db.properties:

jdbc.jdbcUrl=jdbc:mysql:///hibernate_32
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=1234

 applicationContext.xml:

<!-- 指定spring读取db.properties配置 -->
<context:property-placeholder location="classpath:db.properties"  />

<!-- 1.将连接池放入spring容器 -->
<bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" >
	<property name="jdbcUrl" value="${jdbc.jdbcUrl}" ></property>
	<property name="driverClass" value="${jdbc.driverClass}" ></property>
	<property name="user" value="${jdbc.user}" ></property>
	<property name="password" value="${jdbc.password}" ></property>
</bean>

2.spring中的事务

    spring封装了事务管理代码。(打开事务,提交事务,回滚事务)。

    因为在不同平台,操作事务的代码各不相同,所以spring提供了一个接口,PlatformTransactionManager接口。

  • DataSourceTransactionManager;
  • HibernateTransactionManager;

spring管理事务的属性介绍:

  • 事务的隔离级别;
  • 是否只读;true:只读;false:可操作
  • 事务的传播行为。

事务传播行为:决定业务方法之间调用,事务应该如何处理。(PROPAGION_XXX  :事务的传播行为)    

* 保证同一个事务中

  • PROPAGATION_REQUIRED  支持当前事务,如果不存在 就新建一个(默认)
  • PROPAGATION_SUPPORTS  支持当前事务,如果不存在,就不使用事务
  • PROPAGATION_MANDATORY 支持当前事务,如果不存在,抛出异常 

* 保证没有在同一个事务中

  • PROPAGATION_REQUIRES_NEW 如果有事务存在,挂起当前事务,创建一个新的事务
  • PROPAGATION_NOT_SUPPORTED 以非事务方式运行,如果有事务存在,挂起当前事务 
  • PROPAGATION_NEVER  以非事务方式运行,如果有事务存在,抛出异常 
  • PROPAGATION_NESTED 如果当前事务存在,则嵌套事务执行 

spring管理事务方式:

  • 编码式;
  • xml配置(aop);
  • 注解配置(aop);

xml配置:

<!-- 配置事务通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager" >
	<tx:attributes>
		<!-- 以方法为单位,指定方法应用什么事务属性
			isolation:隔离级别
			propagation:传播行为
			read-only:是否只读
		 -->
		<tx:method name="save*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="persist*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="update*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="modify*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="delete*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="remove*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
		<tx:method name="get*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
		<tx:method name="find*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
		<tx:method name="transfer" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
	</tx:attributes>
</tx:advice>


<!-- 配置织入 -->
<aop:config  >
	<!-- 配置切点表达式 -->
	<aop:pointcut expression="execution(* cn.itcast.service.*ServiceImpl.*(..))" id="txPc"/>
	<!-- 配置切面 : 通知+切点
		 	advice-ref:通知的名称
		 	pointcut-ref:切点的名称
	 -->
	<aop:advisor advice-ref="txAdvice" pointcut-ref="txPc" />
</aop:config>

注解配置:

<!-- 开启使用注解管理aop事务 -->
<tx:annotation-driven/>

    注解在方法上加也OK,在类上加也OK。 

  
@Transactional(isolation=Isolation.REPEATABLE_READ,propagation=Propagation.REQUIRED,readOnly=false)
public void transfer(final Integer from,final Integer to,final Double money) {
		//减钱
		ad.decreaseMoney(from, money);
		int i = 1/0;
		//加钱
		ad.increaseMoney(to, money);
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值