iamberry-wechat-service-datasource.xml 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:aop="http://www.springframework.org/schema/aop"
  5. xmlns:context="http://www.springframework.org/schema/context"
  6. xmlns:tx="http://www.springframework.org/schema/tx"
  7. xmlns:p="http://www.springframework.org/schema/p"
  8. xsi:schemaLocation="http://www.springframework.org/schema/beans
  9. http://www.springframework.org/schema/beans/spring-beans.xsd
  10. http://www.springframework.org/schema/aop
  11. http://www.springframework.org/schema/aop/spring-aop.xsd
  12. http://www.springframework.org/schema/context
  13. http://www.springframework.org/schema/context/spring-context.xsd
  14. http://www.springframework.org/schema/tx
  15. http://www.springframework.org/schema/tx/spring-tx.xsd">
  16. <!--理由加密使用-->
  17. <bean id="jdbcUrlBean" class="com.iamberry.wechat.tools.DataSourceManager"></bean>
  18. <!--ratfw后台配置库数据源-->
  19. <bean id="ratfwDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
  20. <property name="driverClass" value="#{jdbcUrlBean.jdbcDriver}"></property>
  21. <property name="jdbcUrl" value="#{jdbcUrlBean.jdbcUrl}"></property>
  22. <property name="user" value="#{jdbcUrlBean.jdbcUserName}"></property>
  23. <property name="password" value="#{jdbcUrlBean.jdbcPassword}"></property>
  24. <!--连接池初始化值 -->
  25. <property name="initialPoolSize" value="3"></property>
  26. <!--连接池最大值 -->
  27. <property name="maxPoolSize" value="#{jdbcUrlBean.maxPoolSize}"></property>
  28. <!--最小空闲值,当空闲连接少于阀值时,连接池会预申请一些连接 -->
  29. <property name="minPoolSize" value="2"></property>
  30. </bean>
  31. <!-- 配置SqlSessionFactoryBean -->
  32. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  33. <!-- 配置数据源 -->
  34. <property name="dataSource" ref="ratfwDataSource" />
  35. <property name="configLocation" value="classpath:iamberry-wechat-service-mybatis.xml" />
  36. <property name="mapperLocations" value="classpath:com/iamberry/wechat/service/mapper/*.xml" />
  37. </bean>
  38. <!-- 自动扫描SQL隐射文件 -->
  39. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  40. <!-- basePackage:指定SQL映射文件、接口的包,自动加载SQL映射文件和接口 -->
  41. <property name="basePackage" value="com.iamberry.wechat.service.mapper"></property>
  42. <!-- 引用SQLSessionFactoryBean -->
  43. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
  44. </bean>
  45. <!-- 事物管理 -->
  46. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  47. <property name="dataSource" ref="ratfwDataSource" />
  48. </bean>
  49. <!-- 注解方式配置事物 在service中@Transactional
  50. <tx:annotation-driven transaction-manager="transactionManager" /> -->
  51. <tx:advice id="webTxAdvice" transaction-manager="transactionManager">
  52. <tx:attributes>
  53. <!-- 需要多个service协同操作,并需要事务支持的均以doxxx开头-->
  54. <tx:method name="do*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception"/>
  55. <tx:method name="delete*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception"/>
  56. <tx:method name="insert*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  57. <tx:method name="update*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  58. <tx:method name="synUpdate*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  59. <tx:method name="save*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  60. <!-- 凡是查询,都不开协同操作 -->
  61. <tx:method name="get*" read-only="true" propagation="SUPPORTS"/>
  62. <tx:method name="find*" read-only="true" propagation="SUPPORTS"/>
  63. <tx:method name="query*" read-only="true" propagation="SUPPORTS"/>
  64. <tx:method name="is*" read-only="true" propagation="SUPPORTS"/>
  65. <tx:method name="*" propagation="REQUIRED" rollback-for="java.lang.Exception"/>
  66. </tx:attributes>
  67. </tx:advice>
  68. <!-- 事务处理 -->
  69. <!-- 事物切入点 -->
  70. <aop:config>
  71. <aop:pointcut expression="execution(* com.iamberry.wechat.service.*.*.*(..))" id="userPoint" />
  72. <aop:advisor advice-ref="webTxAdvice" pointcut-ref="userPoint" />
  73. </aop:config>
  74. </beans>