iamberry-answer-service-datasource.xml 4.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. <!--cdk数据源-->
  32. <!--动态数据源
  33. <bean id="dataSource" class="com.rat.shop.core.database.DataSourceConstant">
  34. <property name="targetDataSources">
  35. <map>
  36. <entry key="db_service" value-ref="ratfwDataSource" />
  37. </map>
  38. </property>
  39. <property name="defaultTargetDataSource" ref="ratfwDataSource" />
  40. </bean> -->
  41. <!-- 配置SqlSessionFactoryBean -->
  42. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  43. <!-- 配置数据源 -->
  44. <property name="dataSource" ref="ratfwDataSource" />
  45. <property name="configLocation" value="classpath:iamberry-answer-service-mybatis.xml" />
  46. <property name="mapperLocations" value="classpath:com/iamberry/answer/service/mapper/*.xml" />
  47. </bean>
  48. <!-- 自动扫描SQL隐射文件 -->
  49. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  50. <!-- basePackage:指定SQL映射文件、接口的包,自动加载SQL映射文件和接口 -->
  51. <property name="basePackage" value="com.iamberry.answer.service.mapper"></property>
  52. <!-- 引用SQLSessionFactoryBean -->
  53. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
  54. </bean>
  55. <!-- 事物管理 -->
  56. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  57. <property name="dataSource" ref="ratfwDataSource" />
  58. </bean>
  59. <!-- 注解方式配置事物 在service中@Transactional
  60. <tx:annotation-driven transaction-manager="transactionManager" /> -->
  61. <tx:advice id="webTxAdvice" transaction-manager="transactionManager">
  62. <tx:attributes>
  63. <!-- 需要多个service协同操作,并需要事务支持的均以doxxx开头-->
  64. <tx:method name="do*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception"/>
  65. <tx:method name="delete*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception"/>
  66. <tx:method name="insert*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  67. <tx:method name="update*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  68. <tx:method name="synUpdate*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  69. <tx:method name="save*" propagation="REQUIRED" read-only="false" rollback-for="java.lang.Exception" />
  70. <!-- 凡是查询,都不开协同操作 -->
  71. <tx:method name="get*" read-only="true" propagation="SUPPORTS"/>
  72. <tx:method name="find*" read-only="true" propagation="SUPPORTS"/>
  73. <tx:method name="query*" read-only="true" propagation="SUPPORTS"/>
  74. <tx:method name="is*" read-only="true" propagation="SUPPORTS"/>
  75. <tx:method name="*" propagation="REQUIRED" rollback-for="java.lang.Exception"/>
  76. </tx:attributes>
  77. </tx:advice>
  78. <!-- 事务处理 -->
  79. <!-- 事物切入点 -->
  80. <aop:config>
  81. <aop:pointcut expression="execution(* com.iamberry.answer.service.*.*.*(..))" id="userPoint" />
  82. <aop:advisor advice-ref="webTxAdvice" pointcut-ref="userPoint" />
  83. </aop:config>
  84. <!--<tx:annotation-driven transaction-manager="ratfwDataSource"></tx:annotation-driven>
  85. <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" p:dataSource-ref="ratfwDataSource" />-->
  86. </beans>