Spring事务——使用XML Schema配置事务策略

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring事务——使用XML Schema配置事务策略相关的知识,希望对你有一定的参考价值。

Spring同时支持编程式事务策略和声明式事务策略,通常推荐采用声明式事务策略。具体实现过程如下:

1.定义一个接口NewsDao,代码如下:

package com.hyq.chapter08_06_2.dao;

public interface NewsDao {

    public void  insert(String title,String content);
    
}

2.定义接口的实现类NewsDaoImpl,代码如下:

 1 package com.hyq.chapter08_06_2.dao.impl;
 2 
 3 import javax.sql.DataSource;
 4 
 5 import org.springframework.jdbc.core.JdbcTemplate;
 6 
 7 import com.hyq.chapter08_06_2.dao.NewsDao;
 8 public class NewsDaoImpl implements NewsDao{
 9 
10     private DataSource ds;
11     
12     public void setDs(DataSource ds) {
13         this.ds = ds;
14     }
15 
16     @Override
17     public void insert(String title, String content) {
18         // TODO Auto-generated method stub
19         JdbcTemplate jt = new JdbcTemplate(ds);
20         jt.update("insert into news_inf values(1,?,?)",title,content);
21         //两次插入的数据违反了唯一性约束
22         jt.update("insert into news_inf values(1,?,?)",title,content);
23         
24         //如果没有事务,则第一条记录可以被插入
25         //如果增加事务控制,将发现第一条记录也插不进去
26     }
27 
28     
29     
30     
31 }

3.定义配置文件bean.xml

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 3     xmlns="http://www.springframework.org/schema/beans"
 4     xmlns:aop="http://www.springframework.org/schema/aop"
 5     xmlns:p="http://www.springframework.org/schema/p"
 6     xmlns:cache="http://www.springframework.org/schema/cache"
 7     xmlns:context="http://www.springframework.org/schema/context"
 8     xmlns:tx="http://www.springframework.org/schema/tx"
 9     xsi:schemaLocation="http://www.springframework.org/schema/beans
10     http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
11     http://www.springframework.org/schema/context
12     http://www.springframework.org/schema/context/spring-context-4.0.xsd
13     http://www.springframework.org/schema/aop
14     http://www.springframework.org/schema/aop/spring-aop.xsd
15     http://www.springframework.org/schema/tx
16     http://www.springframework.org/schema/tx/spring-tx.xsd
17     http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache.xsd">
18     
19     
20     <!-- 定义数据源Bean,使用C3P0数据源实现,并注入数据源的必要信息 -->
21     <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
22         destroy-method="close"
23         p:driverClass="com.mysql.jdbc.Driver"
24         p:jdbcUrl="jdbc:mysql://localhost/db_spring"
25         p:user="root"
26         p:password="111"
27         p:maxPoolSize="40"
28         p:minPoolSize="2"
29         p:initialPoolSize="2"
30         p:maxIdleTime="30"/>
31     
32     
33     <!-- 配置JDBC 数据源的局部事务管理器,使用DataSourceTransactionManager类 -->
34     <!-- 该类实现PlatformTransactionManager接口,是针对采用数据源连接的特定实现 -->
35     <!-- 配置DataSourceTransactionManager时需要依赖注入DataSource的引用 -->
36     <bean id="transactionManager"
37         class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
38         p:dataSource-ref="dataSource"/>
39         
40        <!-- 配置一个业务逻辑Bean -->
41        <bean id="newsDao" class="com.hyq.chapter08_06_2.dao.impl.NewsDaoImpl" p:ds-ref="dataSource"/>
42        
43        <!-- 配置事务增强处理Bean,指定事务管理器 -->
44        <tx:advice id="txAdvice"
45            transaction-manager="transactionManager">
46            <!-- 用于配置详细的事务定义 -->
47            <tx:attributes>
48                <!-- 所有以get开头的方法都是只读的 -->
49                <tx:method name="get*" read-only="true"/>
50                <!-- 其他方法用默认的事务设置,指定超时时长为5秒 -->
51                <tx:method name="*" isolation="DEFAULT" propagation="REQUIRED" timeout="5"/>
52            </tx:attributes>
53        </tx:advice>
54        
55        <!-- AOP配置的元素 -->
56        <aop:config>
57            <aop:pointcut expression="execution(* com.hyq.chapter08_06_2.dao.impl.*Impl.*(..))" id="myPointcut"/>
58            <aop:advisor advice-ref="txAdvice" pointcut-ref="myPointcut"/>
59        </aop:config>
60 </beans>

4.编写一个测试类SpringTest

 1 package com.hyq.chapter08_06_2;
 2 
 3 import org.springframework.context.ApplicationContext;
 4 import org.springframework.context.support.ClassPathXmlApplicationContext;
 5 
 6 import com.hyq.chapter08_06_2.dao.NewsDao;
 7 
 8 
 9 public class SpringTest {
10 
11     public static void main(String[] args) {
12         ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
13         NewsDao dao = (NewsDao)ctx.getBean("newsDao",NewsDao.class);
14         dao.insert("标题", "测试插入的内容");
15     }
16 }

通过执行该测试程序可以看出NewsDaoImpl这个类的方法已经具备了事务性,即当插入过程中出现异常时,查看数据库可以发现一条记录也没插入成功,如果程序不具备事务性的话,则查看数据库会发现程序能够插入一条数据。

 

PS:如果想用注解来配置事务,则可以把上面bean.xml中的43到59行的代码替换成如下配置文件:

<!--   其中<tx:annotation-driven/>的 transaction-manager属性的默认值为transactionManager     -->
<tx:annotation-driven/>
然后在dao的实现类,即NewsDaoImpl.java的class前面加上事务的注释@Transactional(),这样的话,该dao实现类的所有方法都具有事务性

以上是关于Spring事务——使用XML Schema配置事务策略的主要内容,如果未能解决你的问题,请参考以下文章

spring 配置事务xml

Spring事务管理那些事

spring 事务配置

spring基于xml的声明式事务控制配置步骤

spring基于xml的声明式事务控制

Java框架spring 学习笔记(二十):事务管理(注解管理)