<?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:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-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/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd" default-autowire="byName"> <!-- 注意上面的default-autowire="byName",如果没有这个声明那么HibernateDaoSupport中 的sessionFactory不会被注入 --> <!-- 自动扫描组件,这里要把web下面的 controller去除,他们是在springMVC-mvc.xml中配置的, 如果不去除会影响事务管理的。--> <context:component-scan base-package="org.vo"> <context:exclude-filter type="regex" expression="org.controller.*"/> </context:component-scan> <bean id="jotm" class="org.springframework.transaction.jta.JotmFactoryBean" /> <!-- JTA事务管理器 --> <bean id="myJtaManager" class="org.springframework.transaction.jta.JtaTransactionManager"> <property name="userTransaction" ref="jotm" /> </bean> <bean id="defaultSource" class="org.enhydra.jdbc.pool.StandardXAPoolDataSource" destroy-method="shutdown"> <property name="dataSource"> <bean class="org.enhydra.jdbc.standard.StandardXADataSource" destroy-method="shutdown"> <property name="transactionManager" ref="jotm"></property> <property name="driverName" value="net.sourceforge.jtds.jdbc.Driver"></property> <property name="url" value="jdbc:jtds:sqlserver://127.0.0.1:1433/Interface;user=sa;password=123"></property> </bean> </property> <property name="user" value="sa"></property> <property name="password" value="123"></property> <property name="maxSize" value="1000"></property> <property name="minSize" value="2"></property> <property name="lifeTime" value="10"/> <property name="deadLockMaxWait" value="50"/> <property name="deadLockRetryWait" value="3"/> <property name="sleepTime" value="100"/> <!-- 自动重连 --> <property name="jdbcTestStmt" value="select 1" /> <property name="checkLevelObject" value="2"/> </bean> <bean id="theSecondSource" class="org.enhydra.jdbc.pool.StandardXAPoolDataSource" destroy-method="shutdown"> <property name="dataSource"> <bean class="org.enhydra.jdbc.standard.StandardXADataSource" destroy-method="shutdown"> <property name="transactionManager" ref="jotm"></property> <property name="driverName" value="net.sourceforge.jtds.jdbc.Driver"></property> <property name="url" value="jdbc:jtds:sqlserver://127.0.0.1:1433/InterfaceApp;user=sa;password=123"></property> </bean> </property> <property name="user" value="sa"></property> <property name="password" value="123"></property> <property name="maxSize" value="10"></property> <property name="minSize" value="2"></property> <property name="lifeTime" value="10"/> <property name="deadLockMaxWait" value="50"/> <property name="deadLockRetryWait" value="3"/> <property name="sleepTime" value="100"/> <!-- 自动重连 --> <property name="jdbcTestStmt" value="select 1" /> <property name="checkLevelObject" value="2"/> </bean> <!--定义了Hibernate的SessionFactory --> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="defaultSource"></property> <property name="jtaTransactionManager" ref="jotm" /> <!-- 配置Hibernate的参数 --> <property name="hibernateProperties"> <props> <prop key="hibernate.current_session_context_class"> jta </prop> <prop key="hibernate.transaction.factory_class"> org.hibernate.transaction.CMTTransactionFactory </prop> <!-- 指定数据库的方言 --> <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop> <!-- 表示允许自动提交 --> <prop key="hibernate.connection.autocommit">true</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.connection.isolation">2</prop> <!-- JDBC执行批量更新语句的大小 清除缓存(定期清除缓存,减小压力 --> <prop key="hibernate.jdbc.batch_size">50</prop> <!-- <prop key="hibernate.cache.use_query_cache">true</prop>--> <prop key="hibernate.cache.use_second_level_cache">false</prop> <!-- <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>--> </props> </property> <property name="mappingLocations"> <list> <value>classpath*:org/vo/*.hbm.xml</value> <!-- <value>classpath*:org/voapp/*.hbm.xml</value>--> <!-- <value>classpath:org/website/vo/persale/*.hbm.xml</value> --> </list> </property> </bean> <!--定义了Hibernate的SessionFactorySecond --> <bean id="sessionFactorySecond" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="theSecondSource"></property> <property name="jtaTransactionManager" ref="jotm" /> <!-- 配置Hibernate的参数 --> <property name="hibernateProperties"> <props> <prop key="hibernate.current_session_context_class"> jta </prop> <prop key="hibernate.transaction.factory_class"> org.hibernate.transaction.CMTTransactionFactory </prop> <!-- 指定数据库的方言 --> <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop> <!-- 表示允许自动提交 --> <prop key="hibernate.connection.autocommit">true</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.connection.isolation">2</prop> <!-- JDBC执行批量更新语句的大小 清除缓存(定期清除缓存,减小压力 --> <prop key="hibernate.jdbc.batch_size">50</prop> <!-- <prop key="hibernate.cache.use_query_cache">true</prop>--> <prop key="hibernate.cache.use_second_level_cache">false</prop> <!-- <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>--> </props> </property> <property name="mappingLocations"> <list> <!-- <value>classpath*:org/vo/*.hbm.xml</value>--> <value>classpath*:org/voapp/*.hbm.xml</value> <!-- <value>classpath:org/website/vo/persale/*.hbm.xml</value> --> </list> </property> </bean> <tx:advice id="txAdvice" transaction-manager="myJtaManager"> <tx:attributes> <tx:method name="check*" propagation="REQUIRED" read-only="true"/> <tx:method name="query*" propagation="REQUIRED" read-only="true"/> <tx:method name="get*" propagation="REQUIRED" read-only="true"/> <tx:method name="find*" propagation="REQUIRED" read-only="true"/> <tx:method name="is*" propagation="REQUIRED" read-only="true"/> <tx:method name="view*" propagation="REQUIRED" read-only="true"/> <tx:method name="save*" propagation="REQUIRED"/> <tx:method name="update*" propagation="REQUIRED"/> <tx:method name="del*" propagation="REQUIRED"/> <tx:method name="remove*" propagation="REQUIRED"/> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="basePointCuts" expression="execution(* org.service.*.*(..)) and execution(* org.serviceapp.*.*(..))"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="basePointCuts" /> </aop:config> <bean id="baseDao" class="org.dao.impl.BaseDaoImpl" init-method="init" lazy-init="true"> <property name="sessionFactory"> <ref bean="sessionFactory"/> </property> </bean> <bean id="baseDaoSecond" class="org.dao.impl.BaseDaoImpl" init-method="init" lazy-init="true"> <property name="sessionFactory"> <ref bean="sessionFactorySecond"/> </property> </bean> <!-- 读取配置文件 <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location"> <value>/WEB-INF/classes/jdbc.properties</value> </property> </bean> --> <bean id="basicService" class="org.service.BasicService"> <property name="baseDao"> <ref bean="baseDao"/> </property> </bean> </beans>
相关推荐
### Spring事务配置的五种方式详解 #### 一、引言 在企业级应用开发中,事务处理是非常重要的一部分,特别是在涉及多个数据库操作时。Spring框架提供了强大的事务管理功能,支持编程式和声明式两种事务处理方式。...
Spring 事务配置是Spring框架中不可或缺的一部分,它用于管理和协调应用程序中的事务边界,确保数据的一致性和完整性。在Spring中,事务配置主要涉及到三个核心组件:DataSource、TransactionManager和代理机制。...
### SSH事务配置详解 在软件开发领域,特别是Java企业级应用开发中,Spring与Hibernate作为两个重要的框架,常被一起使用来实现业务逻辑层的高效处理。其中,Spring提供了强大的依赖注入(DI)和面向切面编程(AOP...
本文将对三种不同的事务配置方式进行深入探讨:本地事务、全局事务以及结合动态数据源的事务管理。这些配置方式在处理多数据源和复杂业务场景时具有不同的优势和适用性。 首先,我们来看“本地事务”。本地事务通常...
本文将详细介绍Spring事务配置的五种方式,帮助你深入理解如何在Spring应用中管理事务。 1. **基于XML的声明式事务管理** 第一种方式是在每个Bean上使用代理来实现事务管理。首先,配置`DataSource`,通常是`...
本文将深入探讨Spring中的几种事务配置方式,帮助开发者更好地理解和运用。 1. **编程式事务管理** 编程式事务管理是在代码中显式调用事务API来控制事务的开始、提交、回滚等操作。这种方式直接在业务逻辑代码中...
根据提供的信息,我们可以深入探讨Spring框架中的声明式事务配置及其多种实现方式。声明式事务管理是一种简化事务管理的方式,它允许开发人员通过配置而非编程来指定事务边界,从而减少了代码的复杂性并提高了可维护...
Spring声明式事务配置管理方法
### MySQL支持事务配置及启用InnoDB引擎详解 #### 一、引言 MySQL是一种广泛使用的开源关系型数据库管理系统,以其高性能、稳定性和易用性而闻名。其中,InnoDB存储引擎因其支持事务处理、行级锁定和外键等功能,...
4. **事务配置**:在Spring中,事务管理有两种方式:编程式事务管理和声明式事务管理。通常我们采用声明式事务管理,通过`<tx:annotation-driven>`标签启用基于注解的事务管理。事务的传播行为、隔离级别、超时时间...
Spring 事务配置是Spring框架中不可或缺的部分,它用于管理和协调应用程序中的事务边界,确保数据的一致性和完整性。在Spring中,事务配置主要涉及到三个核心组件:DataSource、TransactionManager以及代理机制。...
本文将详细介绍这三大框架在事务配置方面的知识,以及如何进行通用的事务管理设置。 1. **Spring 事务管理** Spring 提供了两种事务管理方式:编程式事务管理和声明式事务管理。编程式事务管理通过 `...
在Spring框架中,声明式事务管理是通过元数据(如XML配置或注解)来定义事务边界,使得开发者无需在业务代码中显式调用事务管理API,即可实现事务的控制。TransactionProxyFactoryBean是Spring提供的一种工具,用于...
Spring提供了多种事务配置方式,主要涉及三个方面:DataSource、TransactionManager和代理机制。下面将详细解释这五个配置方法。 1. **DataSource**:DataSource是Spring与数据库交互的基础,通常负责连接池的管理...