Spring多数据源配置和使用

简介: Spring多数据源配置和使用 1、配置信息 <!--==============================bpt_mobdb数据库配置============================--> <bean id="bpt_mobdb" class="org.

Spring多数据源配置和使用

1、配置信息

    <!--==============================bpt_mobdb数据库配置============================-->

    <bean id="bpt_mobdb" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver">
        </property>
        <property name="url"
                  value="${database.bpt.url}">
        </property>
        <property name="username" value="${database.bpt.username}"></property>
        <property name="password" value="${database.bpt.password}"></property>
        <property name="maxIdle" value="${maxIdle}"/>
        <property name="minIdle" value="${minIdle}"/>
        <property name="maxActive" value="${maxActive}"/>
        <property name="removeAbandoned" value="true"/>
        <property name="removeAbandonedTimeout" value="${removeAbandonedTimeout}"/>
        <property name="maxWait" value="${maxWait}"/>
        <property name="validationQuery">
            <value>SELECT 1</value>
        </property>
    </bean>

    <bean id="bptSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="bpt_mobdb"/>
        <property name="configLocation" value="classpath:com/qingqing/bpt/META-INF/mybatis/mybatis-config.xml"/>
    </bean>
    <!--   事务配置   -->
    <bean id="dataTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="bpt_mobdb"/>
        <!--   事务别称   使用时 @Transactional("bpt_mobdb")  不同数据源需要配不同的事务 -->
        <qualifier value="bpt_mobdb"/>
    </bean>
    <tx:annotation-driven transaction-manager="dataTransactionManager"/>
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="sqlSessionFactoryBeanName" value="bptSqlSessionFactory"/>
        <!--   每个数据源对应的mapper,再该mapper下可以直接操作该数据源   -->
        <property name="basePackage" value="com.qingqing.bpt.mapper"/>
    </bean>

        <!--==============================dim_mobdb数据库配置============================-->

    <bean id="dim_mobdb" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver">
        </property>
        <property name="url" value="${database.dim.url}"></property>
        <property name="username" value="${database.dim.username}"></property>
        <property name="password" value="${database.dim.password}"></property>

        <property name="maxIdle" value="${maxIdle}"/>
        <property name="minIdle" value="${minIdle}"/>
        <property name="maxActive" value="${maxActive}"/>
        <property name="removeAbandoned" value="true"/>
        <property name="removeAbandonedTimeout" value="${removeAbandonedTimeout}"/>
        <property name="maxWait" value="${maxWait}"/>
        <property name="validationQuery">
            <value>SELECT 1</value>
        </property>
    </bean>

    <bean id="dimSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dim_mobdb"/>
        <property name="configLocation" value="classpath:com/qingqing/bpt/META-INF/mybatis/mybatis-config.xml"/>
    </bean>

    <tx:annotation-driven transaction-manager="dim_dataTransactionManager"/>
    <bean id="dim_dataTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dim_mobdb"/>
        <qualifier value="dim_mobdb"/>
    </bean>

    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="sqlSessionFactoryBeanName" value="dimSqlSessionFactory"/>
        <property name="basePackage" value="com.qingqing.dim.mapper"/>
    </bean>

    <!--==============================conf_mobdb数据库配置============================-->

    <bean id="conf_mobdb" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver">
        </property>
        <property name="url" value="${database.conf.url}"></property>
        <property name="username" value="${database.conf.username}"></property>
        <property name="password" value="${database.conf.password}"></property>

        <property name="maxIdle" value="${maxIdle}"/>
        <property name="minIdle" value="${minIdle}"/>
        <property name="maxActive" value="${maxActive}"/>
        <property name="removeAbandoned" value="true"/>
        <property name="removeAbandonedTimeout" value="${removeAbandonedTimeout}"/>
        <property name="maxWait" value="${maxWait}"/>
        <property name="validationQuery">
            <value>SELECT 1</value>
        </property>
    </bean>

    <bean id="confSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="conf_mobdb"/>
        <property name="configLocation" value="classpath:com/qingqing/bpt/META-INF/mybatis/mybatis-config.xml"/>
    </bean>

    <tx:annotation-driven transaction-manager="conf_dataTransactionManager"/>
    <bean id="conf_dataTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="conf_mobdb"/>
        <qualifier value="conf_mobdb"/>
    </bean>

    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="sqlSessionFactoryBeanName" value="confSqlSessionFactory"/>
        <property name="basePackage" value="com.qingqing.conf.mapper"/>
    </bean>

2、使用

不同数据源关联操作:     库名.表名

select a.*,b.* bpt_mobdb.tableA a left join dim_mobdb.tableB b on a.id = b.user_id

原文地址http://www.bieryun.com/3232.html

相关文章
|
5月前
|
SQL 监控 druid
springboot-druid数据源的配置方式及配置后台监控-自定义和导入stater(推荐-简单方便使用)两种方式配置druid数据源
这篇文章介绍了如何在Spring Boot项目中配置和监控Druid数据源,包括自定义配置和使用Spring Boot Starter两种方法。
|
15天前
|
XML Java 测试技术
Spring IOC—基于注解配置和管理Bean 万字详解(通俗易懂)
Spring 第三节 IOC——基于注解配置和管理Bean 万字详解!
98 26
|
2月前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
181 73
|
4月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
78 4
|
3月前
|
Java 开发者 微服务
手写模拟Spring Boot自动配置功能
【11月更文挑战第19天】随着微服务架构的兴起,Spring Boot作为一种快速开发框架,因其简化了Spring应用的初始搭建和开发过程,受到了广大开发者的青睐。自动配置作为Spring Boot的核心特性之一,大大减少了手动配置的工作量,提高了开发效率。
79 0
|
4月前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
85 0
|
28天前
|
监控 Java 数据库连接
Spring c3p0配置详解
在Spring项目中配置C3P0数据源,可以显著提高数据库连接的效率和应用程序的性能。通过合理的配置和优化,可以充分发挥C3P0的优势,满足不同应用场景的需求。希望本文的详解和示例代码能为开发者提供清晰的指导,帮助实现高效的数据库连接管理。
47 10
|
2月前
|
Java Spring
【Spring配置相关】启动类为Current File,如何更改
问题场景:当我们切换类的界面的时候,重新启动的按钮是灰色的,不能使用,并且只有一个Current File 项目,下面介绍两种方法来解决这个问题。
|
2月前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
2月前
|
Java Spring
【Spring配置】创建yml文件和properties或yml文件没有绿叶
本文主要针对,一个项目中怎么创建yml和properties两种不同文件,进行配置,和启动类没有绿叶标识进行解决。