SpringMVC配置双数据源,一个java项目同时连接两个数据库
数据源在配置文件中的配置
请点击---》 java架构师项目实战,高并发集群分布式,大数据高可用,视频教程
- <pre name="code" class="java"><?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:cache="http://www.springframework.org/schema/cache"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:jee="http://www.springframework.org/schema/jee"
- xmlns:jms="http://www.springframework.org/schema/jms" xmlns:lang="http://www.springframework.org/schema/lang"
- xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:oxm="http://www.springframework.org/schema/oxm"
- xmlns:p="http://www.springframework.org/schema/p" xmlns:task="http://www.springframework.org/schema/task"
- xmlns:tx="http://www.springframework.org/schema/tx" xmlns:util="http://www.springframework.org/schema/util"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
- http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd
- http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.1.xsd
- http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.1.xsd
- http://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-3.1.xsd
- http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-3.1.xsd
- http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd
- http://www.springframework.org/schema/oxm http://www.springframework.org/schema/oxm/spring-oxm-3.1.xsd
- http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.1.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
- http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.1.xsd">
- <context:annotation-config />
- <context:component-scan base-package="com"></context:component-scan>
- <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="locations">
- <list>
- <value>classpath:com/resource/config.properties</value>
- </list>
- </property>
- </bean>
- <bean id="dataSourceOne" class="com.mchange.v2.c3p0.ComboPooledDataSource"
- destroy-method="close">
- <property name="driverClass" value="${dbOne.jdbc.driverClass}" />
- <property name="jdbcUrl" value="${dbOne.jdbc.url}" />
- <property name="user" value="${dbOne.jdbc.user}" />
- <property name="password" value="${dbOne.jdbc.password}" />
- <property name="initialPoolSize" value="${dbOne.jdbc.initialPoolSize}" />
- <property name="minPoolSize" value="${dbOne.jdbc.minPoolSize}" />
- <property name="maxPoolSize" value="${dbOne.jdbc.maxPoolSize}" />
- </bean>
- <bean id="dataSourceTwo" class="com.mchange.v2.c3p0.ComboPooledDataSource"
- destroy-method="close">
- <property name="driverClass" value="${dbTwo.jdbc.driverClass}" />
- <property name="jdbcUrl" value="${dbTwo.jdbc.url}" />
- <property name="user" value="${dbTwo.jdbc.user}" />
- <property name="password" value="${dbTwo.jdbc.password}" />
- <property name="initialPoolSize" value="${dbTwo.jdbc.initialPoolSize}" />
- <property name="minPoolSize" value="${dbTwo.jdbc.minPoolSize}" />
- <property name="maxPoolSize" value="${dbTwo.jdbc.maxPoolSize}" />
- </bean>
- <bean id="dynamicDataSource" class="com.core.DynamicDataSource">
- <property name="targetDataSources">
- <map key-type="java.lang.String">
- <entry value-ref="dataSourceOne" key="dataSourceOne"></entry>
- <entry value-ref="dataSourceTwo" key="dataSourceTwo"></entry>
- </map>
- </property>
- <property name="defaultTargetDataSource" ref="dataSourceOne">
- </property>
- </bean>
- <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
- <property name="dataSource" ref="dynamicDataSource" />
- <property name="hibernateProperties">
- <props>
- <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
- <prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext</prop>
- <prop key="hibernate.show_sql">false</prop>
- <prop key="hibernate.format_sql">true</prop>
- <prop key="hbm2ddl.auto">create</prop>
- </props>
- </property>
- <property name="packagesToScan">
- <list>
- <value>com.po</value>
- </list>
- </property>
- </bean>
- <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
- <property name="sessionFactory" ref="sessionFactory" />
- </bean>
- <aop:config>
- <aop:pointcut id="transactionPointCut" expression="execution(* com.dao..*.*(..))" />
- <aop:advisor advice-ref="txAdvice" pointcut-ref="transactionPointCut" />
- </aop:config>
- <tx:advice id="txAdvice" transaction-manager="transactionManager">
- <tx:attributes>
- <tx:method name="add*" propagation="REQUIRED" />
- <tx:method name="save*" propagation="REQUIRED" />
- <tx:method name="update*" propagation="REQUIRED" />
- <tx:method name="delete*" propagation="REQUIRED" />
- <tx:method name="*" read-only="true" />
- </tx:attributes>
- </tx:advice>
- <aop:config>
- <aop:aspect id="dataSourceAspect" ref="dataSourceInterceptor">
- <aop:pointcut id="daoOne" expression="execution(* com.dao.one.*.*(..))" />
- <aop:pointcut id="daoTwo" expression="execution(* com.dao.two.*.*(..))" />
- <aop:before pointcut-ref="daoOne" method="setdataSourceOne" />
- <aop:before pointcut-ref="daoTwo" method="setdataSourceTwo" />
- </aop:aspect>
- </aop:config>
- </beans>
请点击---》 java架构师项目实战,高并发集群分布式,大数据高可用,视频教程
DynamicDataSource.class
- package com.core;
- import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
- public class DynamicDataSource extends AbstractRoutingDataSource{
- @Override
- protected Object determineCurrentLookupKey() {
- return DatabaseContextHolder.getCustomerType();
- }
- }
DatabaseContextHolder.class设置数据源的类
- package com.core;
- public class DatabaseContextHolder {
- private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();
- <span style="white-space:pre"> </span>//设置要使用的数据源
- public static void setCustomerType(String customerType) {
- contextHolder.set(customerType);
- }
- <span style="white-space:pre"> </span>//获取数据源
- public static String getCustomerType() {
- return contextHolder.get();
- }
- <span style="white-space:pre"> </span>//清除数据源,使用默认的数据源
- public static void clearCustomerType() {
- contextHolder.remove();
- }
- }
DataSourceInterceptor.class
- package com.core;
- import org.aspectj.lang.JoinPoint;
- import org.springframework.stereotype.Component;
- @Component
- public class DataSourceInterceptor {
- <span style="white-space:pre;"> </span>//数据源1
- public static final String SOURCE_PLAN = "dataSourceOne;
- //数据源2
- public static final String SOURCE_FUND = dataSourceTwo;
}
请点击---》 java架构师项目实战,高并发集群分布式,大数据高可用,视频教程
springMVC数据源
- jdbc_driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
- dataSourceOne=jdbc:sqlserver://115.29.***.**;DatabaseName=DB_GuiHua
jdbc_username=**jdbc_password=**
- dataSourceTwo=jdbc:sqlserver://115.29.***.*;DatabaseName=DB_Fund
Spring MVC会默认有一个数据源,当需要更换数据源时,要在调用事务之前配置
- DataSourceContextHolder.setDbType(DataSourceType.SOURCE_FUND);//更换数据源
- /**
- * @ClassName: DataSourceContextHolder
- * @Description: 数据库切换工具类
- * @author: wzx
- * @date: 2016-07-27 上午10:26:01
- */
- public class DataSourceContextHolder {
- private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();
- public static void setDbType(String dbType) {
- contextHolder.set(dbType);
- }
- public static String getDbType() {
- return ((String) contextHolder.get());
- }
- public static void clearDbType() {
- contextHolder.remove();
- }
- }
请点击---》 java架构师项目实战,高并发集群分布式,大数据高可用,视频教程
SpringMVC配置双数据源,一个java项目同时连接两个数据库的更多相关文章
- spring项目配置双数据源读写分离
我们最早做新项目的时候一直想做数据库的读写分离与主从同步,由于一些原因一直没有去做这个事情,这次我们需要配置双数据源的起因是因为我们做了一个新项目用了另一个数据库,需要把这个数据库的数据显示到原来的后 ...
- java学习笔记(一):开始第一个java项目
这里使用IntelliJ IDEA 来新建第一个java项目 在新建项目向导,你可以选择你的项目支持的技术,你正在做一个普通的Java项目,只需单击下一步. 下一步,新建一个test的项目. 新建一个 ...
- 【系列教程1】Gradle入门系列二:第一个Java项目
这篇教程的主要内容是讲解如何用Gradle编译和打包一个简单的Java项目. 该Java项目只有一个需求:我们的构建脚本必须创建一个可执行的Jar文件,换句话说,我们必须能够使用命令java -jar ...
- 作为Java新手,如何才能快速的看透一个Java项目?
前言 技术学习是一个总结.纠错.触类旁通的过程,而不是单纯重复练习的过程,如果你问一个做过5年以上Java的老码农,他们很多人都会有很强的"搬砖感",这种"搬砖感&quo ...
- 初学者如何吃透一个Java项目
不少初学者朋友在学习Java过程中,会对着视频敲Java项目,其中遇到的BUG还能解决,但就是每次敲完一个项目,就感觉很空虚,项目里面的知识点感觉懂了但又好像没懂 这些朋友应该怎样才能掌握一个项目所用 ...
- 在Eclipse中,如何把一个java项目变成web项目
经常在eclipse中导入web项目时,出现转不了项目类型的问题,导入后就是一个java项目.解决步骤:1.进入项目目录,可看到.project文件,打开.2.找到<natures>... ...
- Node.js npm基础安装配置&创建第一个VUE项目
使用之前,我们先来明白这几个东西是用来干什么的. node.js: 一种javascript的运行环境,能够使得javascript脱离浏览器运行.Node.js的出现,使得前后端使用同一种语言,统一 ...
- 一个Web项目中实现多个数据库存储数据并相互切换用过吗?
最近公司一个项目需要连接多个数据库(A和B)操作,根据不同的业务模块查询不同的数据库,因此需要改造下之前的spring-mybatis.xml配置文件以及jdbc.properties配置文件,项目后 ...
- Springboot配置连接两个数据库
背景: 项目中需要从两个不同的数据库查询数据,之前实现方法是:springboot配置连接一个数据源,另一个使用jdbc代码连接. 为了改进,现在使用SpringBoot配置连接两个数据源 实现效果: ...
随机推荐
- 简易RPC框架-熔断降级机制
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- 晓莲说-何不原创:如何通过jad把class批量反编译成java文件
背景:前几天在项目开发的时候遇到一个问题,那就是利用myeclipse编写好的一个项目打包成jar包后上传部署到服务器里,之后本地的项目被自己改来改去出现了一些问题,想着把上传到服务器里面的war包下 ...
- MVC模式tp框架四中路由形式
①基本get形式 http://网址/index.php?m=分组&c=控制器&a=操作方法 该方法是最底层的get形式,传统的传递参数方式,不安全. ②pathinfo路径形式[默认 ...
- (四):C++分布式框架——状态中心模块
(四):C++分布式框架--状态中心模块 上篇:(三):C++分布式实时应用框架--系统管理模块 技术交流合作QQ群:436466587 欢迎讨论交流 版权声明:本文版权及所用技术归属smartguy ...
- 命令模式(Command)
命令模式(Command) 命令模式很好理解,举个例子,司令员下令让士兵去干件事情,从整个事情的角度来考虑,司令员的作用是,发出口令,口令经过传递,传到了士兵耳朵里,士兵去执行.这个过程好在,三者相互 ...
- TFS2017持续发布中调用PowerShell启停远程应用程序
目前团队项目中有多个Web.服务以及与大数据平台对接接口等应用,每次的发布和部署采用手工的方式进行.停止应用程序,拷贝发布包,启动应用程序,不停的循环着,并且时不时地会出现一些人为错误性问题.这种模式 ...
- PHP进程锁
<?php /** * CacheLock 进程锁,主要用来进行cache失效时的单进程cache获取,防止过多的SQL请求穿透到数据库 * 用于解决PHP在并发时候的锁控制,通过文件/eacc ...
- mysqldump指定编码导出数据
mysqldump指定编码导出数据 第一步,导出旧库 mysqldump --default-character-set=latin1 -uroot -pXXX --database db > ...
- 关于C++编译链接和模板函数
一,关于编译链接编译指的的把编译单元生成目标文件的过程链接是把目标文件链接到一起的过程编译单元:可以认为是一个.c或者.cpp文件.每个编译单元经过预处理会得到一个临时的编译单元.预处理会间接包含其他 ...
- 直播二:iOS中硬编码(VideoToolBox)
硬编码相对于软编码来说,使用非CPU进行编码,如显卡GPU.专用的DSP.FPGA.ASIC芯片等,性能高,对CPU没有压力,但是对其他硬件要求较高(如GPU等). 在iOS8之后,苹果开放了接口,并 ...