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配置连接两个数据源 实现效果: ...
随机推荐
- 随笔-SQL的三种存储引擎即三种类型的表
MYSQL 的环境变量:......server/bin下 引擎(Engine):是电子平台上开发程序或系统的核心组件.利用引擎,开发者可迅速建立.铺设程序所需的功能,或利用其辅助程序的运转.一般而言 ...
- js的学习(window对象的使用)
open方法: //语法:var winObj = window.open([url][,name][,options]); //参数:url:准备在新窗口中显示那个文件.url可以为空字符串,表示 ...
- 两天快速开发一个自己的微信小程序
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Songti SC" } p.p2 { margin: 0.0px 0. ...
- 【转】千万不要在JS中使用连等赋值操作
原文链接 千万不要在JS中使用连等赋值操作 目录 前言 赋值顺序? 连续赋值能拆开写么? 后记 前言 文章标题这句话原本是在国外某JavaScript规范里看到的,当时并没有引起足够的重视,直到最 ...
- bootstrap fileinput上传返回400,404,500 等错误替换
$(".uploadfile").on('filebatchuploaderror', function(event, data, msg) { $(".file-err ...
- toastr 通知提示插件
table.sb-tb td,table.sb-tb th { padding: 5px 10px !important } jquery toastr 一款轻量级的通知提示框插件. 网页开发中经常会 ...
- php面向对象(OOP)编程完全教程(转载笔记,有兴趣可以看看))
http://www.cnblogs.com/xiaochaohuashengmi/archive/2010/09/10/1823042.html
- 初识java这个小姑娘(二)
妙解垃圾回收机制 周一,早高峰. 一段考验一个人耐力.智力.开车技术以及脾气的路. 我把车开进了一个没有红绿灯的丁字路口,然后就没有然后了. 来自三个方向的大车小车开始在不大的一块空间里开始互相斗智斗 ...
- java学习笔记之StringBuilder
StringBuilder总结 StringBuilder概述: StringBuilder是一个线程不安全的类,他在字符串连接方面性能尤其出色 StringBuilder类的构造方法: 1.空参数构 ...
- NDK开发小记录 C++读取java层对象内容
这是自己NDK开发得小记录,关于C++层读取java层传来的对象内容. 很简单的一个例子, 1.首先在java层定义了一个类NumList: public class NumList { public ...