标签:tran 出现 core ola ssi jdbc spi eth viso
<?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" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <!--配置业务层--> <bean id="accountService" class="com.com.service.impl.AccountServiceImpl"> <property name="accountDao" ref="accountDao"></property> </bean> <!--配置持久层--> <bean id="accountDao" class="com.com.dao.impl.AccountDaoImpl"> <property name="dataSource" ref="dataSource"></property> </bean> <!--<!–配置JdbcTemplate对象–> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"></property> </bean>--> <!--配置数据源 使用spring的内置数据源--> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/spring"></property> <property name="username" value="root"></property> <property name="password" value="root"></property> </bean> <!--spirng中基于xml的声明式事务控制配置步骤 1.配置事务管理器 2.配置事务的通知 使用tx:advice标签配置事务通知 属性: id:给事务通知起一个唯一标识 transaction-manager:给事务通知一个事务管理器引用, 3.配置AOP中的通用切入点表达式 4.建立事务和切入点表达式的对应关系 5.配置事务的属性 在tx:advice标签内部使用tx:attributes标签配置 在tx:attributes标签内部使用tx:method标签 属性: name:添加事务管理的方法名称 可以使用通配符 * ,表示所有方法都会有事务管理且事务遵循配置好的事务属性, 查询方法可以使用 find* ,单独设置事务属性,所以方法命名最好要遵守命名规则,如查询方法以find开头 find* 的优先级高于 * isolation:用于指定事务的隔离级别,默认值是DEFAULT,表示使用数据库的默认隔离级别 propagation:用于指定事务的传播行为,默认值是REQUIRED,表示一定会有事务,增删改的选择,查询方法可以选择SUPPORTS read-only:用于指定事务是否只读,只有查询方法才能设置为true,默认值是false,表示读写 timeout:用于指定事务的超时时间,默认值是-1,表示用不超时,如果指定了数值,以秒为单位 rollback-for:用于指定一个异常,当出现这个异常时,事务回滚,产生其他异常时,事务不回滚,没有默认值,表示任何异常都会回滚 on-rollback-for:用于指定一个异常,当出现这个异常时,事务不回滚,产生其他异常时,事务回滚,没有默认值,表示任何异常都会回滚 --> <!--配置事务管理器--> <bean id="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="*" propagation="REQUIRED" read-only="false"/> <tx:method name="find*" propagation="SUPPORTS" read-only="true"/> </tx:attributes> </tx:advice> <!--配置AOP--> <aop:config> <!--配置AOP中的通用切入点表达式--> <aop:pointcut id="pt1" expression="execution(* com.com.service.impl.*.*(..))"/> <!--建立事务和切入点表达式的对应关系--> <aop:advisor advice-ref="txAdvice" pointcut-ref="pt1"></aop:advisor> </aop:config> </beans>
spring基于xml的声明式事务控制配置步骤
标签:tran 出现 core ola ssi jdbc spi eth viso
原文地址:https://www.cnblogs.com/wqy0314/p/11888428.html