spring多个数据源配置
- sys.properties中的内容
- jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
- DB.url=jdbc\:oracle\:thin\:@****\:1521\:****
- DB.username=****
- DB.password=****
- jdbc.driverClassName2=oracle.jdbc.driver.OracleDriver
- DB.url2=jdbc\:oracle\:thin\:@****\:1521\:****
- DB.username2=****
- DB.password2=****
- Spring配置文件中添加的内容
- <bean id="propertyConfigurer"
- class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="locations">
- <list>
- <!--数据库配置文件-->
- <value>WEB-INF/sys.properties</value>
- </list>
- </property>
- </bean>
- <!-- 配置数据源1 -->
- <bean id="dataSource1" class="org.apache.commons.dbcp.BasicDataSource">
- <property name="driverClassName" value="${jdbc.driverClassName}"/>
- <property name="url" value="${DB.url}"/>
- <property name="username" value="${DB.username}"/>
- <property name="password" value="${DB.password}"/>
- <!--initialSize: 初始化连接-->
- <property name="initialSize" value="5"/>
- <!--maxIdle: 最大空闲连接-->
- <property name="maxIdle" value="3"/>
- <!--minIdle: 最小空闲连接-->
- <property name="minIdle" value="2"/>
- <!--maxActive: 最大连接数量-->
- <property name="maxActive" value="10"/>
- <!--removeAbandoned: 是否自动回收超时连接-->
- <property name="removeAbandoned" value="true"/>
- <!--removeAbandonedTimeout: 超时时间(以秒数为单位)-->
- <property name="removeAbandonedTimeout" value="180"/>
- <!--maxWait: 超时等待时间以毫秒为单位 6000毫秒/1000等于60秒-->
- <property name="maxWait" value="3000"/>
- <property name="poolPreparedStatements" value="false"/>
- <property name="defaultAutoCommit" value="true"/>
- <property name="validationQuery" value="select * from dual"/>
- </bean>
- <!-- 配置数据源2 -->
- <bean id="dataSource2" class="org.apache.commons.dbcp.BasicDataSource">
- <property name="driverClassName" value="${jdbc.driverClassName2}"/>
- <property name="url" value="${DB.url2}"/>
- <property name="username" value="${DB.username2}"/>
- <property name="password" value="${DB.password2}"/>
- <!--initialSize: 初始化连接-->
- <property name="initialSize" value="5"/>
- <!--maxIdle: 最大空闲连接-->
- <property name="maxIdle" value="3"/>
- <!--minIdle: 最小空闲连接-->
- <property name="minIdle" value="2"/>
- <!--maxActive: 最大连接数量-->
- <property name="maxActive" value="10"/>
- <!--removeAbandoned: 是否自动回收超时连接-->
- <property name="removeAbandoned" value="true"/>
- <!--removeAbandonedTimeout: 超时时间(以秒数为单位)-->
- <property name="removeAbandonedTimeout" value="180"/>
- <!--maxWait: 超时等待时间以毫秒为单位 6000毫秒/1000等于60秒-->
- <property name="maxWait" value="3000"/>
- <property name="poolPreparedStatements" value="false"/>
- <property name="defaultAutoCommit" value="true"/>
- <property name="validationQuery" value="select * from dual"/>
- </bean>
- <!-- 事务1 -->
- <bean id="transactionManager1" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource1" />
- </bean>
- <!-- 事务2 -->
- <bean id="transactionManager2" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource2" />
- </bean>
- <!-- 事务拦截1 -->
- <bean id="transactionInterceptor1" class="org.springframework.transaction.interceptor.TransactionInterceptor">
- <property name="transactionManager" ref="transactionManager1" />
- <property name="transactionAttributes">
- <props>
- <prop key="insert*">PROPAGATION_REQUIRED</prop>
- <prop key="delete*">PROPAGATION_REQUIRED</prop>
- <prop key="update*">PROPAGATION_REQUIRED</prop>
- <prop key="do*">PROPAGATION_REQUIRED</prop>
- </props>
- </property>
- </bean>
- <!-- 事务拦截2 -->
- <bean id="transactionInterceptor2" class="org.springframework.transaction.interceptor.TransactionInterceptor">
- <property name="transactionManager" ref="transactionManager2" />
- <property name="transactionAttributes">
- <props>
- <prop key="insert*">PROPAGATION_REQUIRED</prop>
- <prop key="delete*">PROPAGATION_REQUIRED</prop>
- <prop key="update*">PROPAGATION_REQUIRED</prop>
- <prop key="do*">PROPAGATION_REQUIRED</prop>
- </props>
- </property>
- </bean>
- <!-- 管理你连接的地方-->
- <bean id="autoProxyCreator" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
- <property name="beanNames">
- <value>*Service</value>
- </property>
- <property name="interceptorNames">
- <list>
- <value>transactionInterceptor1</value>
- <value>transactionInterceptor2</value>
- </list>
- </property>
- </bean>
- <!-- ibatis的工厂数据源配置1 -->
- <bean id="sqlMapClient1" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
- <property name="configLocation" value="WEB-INF/config/sql-map-config.xml" /><!--这里是ibatis的sqlMap文件集合 -->
- <property name="dataSource" ref="dataSource1" />
- </bean>
- <!-- ibatis的工厂数据源配置2 -->
- <bean id="sqlMapClient2" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
- <property name="configLocation" value="WEB-INF/config/sql-map-config.xml" /><!--这里是ibatis的sqlMap文件集合 -->
- <property name="dataSource" ref="dataSource2" />
- </bean>
- <!-- ibatis抽象的Dao1 -->
- <bean id="baseIbatisDAO1" abstract="true">
- <property name="sqlMapClient">
- <ref local="sqlMapClient1" />
- </property>
- </bean>
- <!-- ibatis抽象的Dao2 -->
- <bean id="baseIbatisDAO2" abstract="true">
- <property name="sqlMapClient">
- <ref local="sqlMapClient2" />
- </property>
- </bean>
- <!--将数据源注入到dao层-->
- <bean id="deptDAO" class="com.cqjk.datasv.dept.DeptDAO" parent="baseIbatisDAO1">
- <property name="sqlmapNamespace">
- <value>dept</value>
- </property>
- </bean>
- <bean id="userDAO" class="com.cqjk.datasv.user.UserDAO" parent="baseIbatisDAO1">
- <property name="sqlmapNamespace">
- <value>user</value>
- </property>
- </bean>
- <bean id="eventsDAO" class="com.cqjk.datasv.events.EventsDAO"
- parent="baseIbatisDAO2">
- <property name="sqlmapNamespace">
- <value>events</value>
- </property>
- </bean>
- <bean id="ddwcDAO" class="com.cqjk.datasv.ddwc.DdwcDAO" parent="baseIbatisDAO2">
- <property name="sqlmapNamespace">
- <value>ddwc</value>
- </property>
- </bean>
- <bean id="ddwcRyDAO" class="com.cqjk.datasv.ddwcry.DdwcRyDAO"
- parent="baseIbatisDAO2">
- <property name="sqlmapNamespace">
- <value>ddwcry</value>
- </property>
- </bean>
spring多个数据源配置的更多相关文章
- spring mysql多数据源配置
spring mysql多数据源配置 @Configuration public class QuartzConfig { @Autowired private AutowireJobFactory ...
- Java spring mvc多数据源配置
1.首先配置两个数据库<bean id="dataSourceA" class="org.apache.commons.dbcp.BasicDataSource&q ...
- Spring Boot多数据源配置(二)MongoDB
在Spring Boot多数据源配置(一)durid.mysql.jpa 整合中已经讲过了Spring Boot如何配置mysql多数据源.本篇文章讲一下Spring Boot如何配置mongoDB多 ...
- Spring实现多数据源配置
一.前言 对于小型项目,服务器与数据库是可以在同一台机子上的,但随着业务的庞大与负责,数据库和服务器就会分离开来.同时随着数据量的增大,数据库也要分开部署到多台机子上. 二.Spring配置文件修改 ...
- JAVA spring hibernate 多数据源配置记录
数据源配置 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http:// ...
- 三、Spring Boot 多数据源配置
下面一个Java类是已经写好的根据配置文件动态创建多dataSource的代码,其原理也很简单,就是读取配置文件,根据配置文件中配置的数据源数量,动态创建dataSource并注册到Spring中. ...
- Spring Boot Druid数据源配置
package com.hgvip.config; import com.alibaba.druid.pool.DruidDataSource; import com.alibaba.druid.su ...
- spring boot多数据源配置(mysql,redis,mongodb)实战
使用Spring Boot Starter提升效率 虽然不同的starter实现起来各有差异,但是他们基本上都会使用到两个相同的内容:ConfigurationProperties和AutoConfi ...
- 21. Spring Boot Druid 数据源配置解析
1.数据源配置属性类源码 package org.springframework.boot.autoconfigure.jdbc; @ConfigurationProperties( prefix = ...
随机推荐
- java 导出excel(简单案例)
public class Student { private int id; private String name; private int age; private Date birth; pub ...
- hdu_4283_You Are the One(区间DP)
题目链接:hdu_4283_You Are the One 题意: 有n个人,每个人有个屌丝值,如果果他是第K个上场,不开心指数就为(K-1)*D,然后有个小黑屋,可以调整他们的出场顺序,现在让你调整 ...
- queue STL
//queue STL //queue is just a container adaptor, which is a class that use other container. //just l ...
- 【Loadrunner】初学Loadrunner——IP欺骗
因为在默认情况下,同一个用户用同一个IP访问运行是不符合实际情况的,而且很多网站会自动屏蔽同个IP多次重复访问.那么就想到了Loadrunner的虚拟IP技术,也就是常说的IP欺骗.在用Loadrun ...
- SharePoint 2013 配置InfoPath 列表表单
转载来源:http://www.cnblogs.com/jianyus/p/3470113.html SharePoint列表,都是通过表单展示,有时候不太符合要求,这时候,我们可以通过定制表单,来是 ...
- Core Animation之多种动画效果
前面介绍了Core Animation基础知识,还有CALayer的简单使用,最终还是有要动画的滴,这里列出几个动画效果,参考下能加深对Core Animation的认识和理解 1.把图片移到右下角变 ...
- HyperSnap(屏幕抓图工具) 8.11.03 官方简体中文特别版
软件名称:屏幕抓图工具HyperSnap 软件分类:图像捕捉运行环境:WinXP/Win2003/Vista/Win7/Win8/WinALL软件语言:简体中文授权方式:免费软件软件大小:12462K ...
- linux命令英文缩写的含义(方便记忆)
命令缩写: ls:list(列出目录内容) cd:Change Directory(改变目录) su:switch user 切换用户 rpm:redhat package manager 红帽子打包 ...
- NYOJ-1036 非洲小孩(贪心)
非洲小孩 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 家住非洲的小孩,都很黑.为什么呢?第一,他们地处热带,太阳辐射严重.第二,他们不经常洗澡.(常年缺水,怎么洗 ...
- android 实践项目
电子词典 http://files.cnblogs.com/blogLYF/lyf_danci.apk