JavaのWebアプリケーション開発フレームワークによる、Webサイト開発の顛末記です。

EclipseのMavenを使った、Spring-MVC、Thymeleaf、MyBatis 等のプログラミングテクニックを、
備忘録的に記録しています。実際に動くソースコードを多用して説明していますので、
これからEclipseや、Spring-MVCを始めたいと思っている人にとって、少しでも参考になれば幸いです。
Spring-MVCの散歩道 > 応用の森(Spring-MVC編) > 複数のDB(データソース)に接続する

<?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:tx="http://www.springframework.org/schema/tx"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-4.3.xsd
        http://mybatis.org/schema/mybatis-spring
        http://mybatis.org/schema/mybatis-spring.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
        ">

    <!--
        ==========================
        MyBatis-spring の設定
        ==========================
    -->

    <!-- アノテーションベースのTransactionManagerアプローチを有効にする -->
    <tx:annotation-driven />

    <!-- JDBC DataSource Configration-->
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations" value="WEB-INF/jdbc.properties" />
    </bean>

     <!-- ==================
         プライマリデータソース定義
     ===================-->
    <bean id="primaryDataSource" class="org.apache.tomcat.dbcp.dbcp2.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="${jdbc.primary.driverClassName}" />
        <property name="url" value="${jdbc.primary.url}" />
        <property name="username" value="${jdbc.primary.username}" />
        <property name="password" value="${jdbc.primary.password}" />
        <property name="defaultAutoCommit" value="false"/>
        <property name="maxIdle" value="5"/>
        <property name="minIdle" value="3"/>
        <property name="initialSize" value="5"/>
    </bean>

    <!-- MyBatis3.x-Spring -->
    <!--SqlSessionFactory Injection -->
    <bean id="primarySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="primaryDataSource" />
        <!-- DTOの型エイリアスを設定するBaseパッケージを宣言する -->
        <property name="typeAliasesPackage" value="jp.dip.arimodoki.model.dto" />
         <!-- XMLMapperファイルの配置先を指定する -->
        <property name="mapperLocations" value="/WEB-INF/mappers/primary/*.xml" />
    </bean>

     <!-- Transaction Manager -->
    <bean id="primaryTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource"><ref bean="primaryDataSource"/></property>
    </bean>

    <!-- Mapperのスキャン -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="jp.dip.arimodoki.mapper.primary" />
        <property name="sqlSessionFactoryBeanName" value="primarySqlSessionFactory" />
    </bean>

     <!--==================
         セカンダリデータソース定義
     ===================-->
    <bean id="secondaryDataSource" class="org.apache.tomcat.dbcp.dbcp2.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="${jdbc.secondary.driverClassName}" />
        <property name="url" value="${jdbc.secondary.url}" />
        <property name="username" value="${jdbc.secondary.username}" />
        <property name="password" value="${jdbc.secondary.password}" />
        <property name="defaultAutoCommit" value="false"/>
        <property name="maxIdle" value="5"/>
        <property name="minIdle" value="3"/>
        <property name="initialSize" value="5"/>
    </bean>

    <!-- MyBatis3.x-Spring -->
    <!--SqlSessionFactory Injection -->
    <bean id="secondarySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="secondaryDataSource" />
        <!-- DTOの型エイリアスを設定するBaseパッケージを宣言する -->
        <property name="typeAliasesPackage" value="jp.dip.arimodoki.model.dto" />
        <!-- XMLMapperファイルの配置先を指定する -->
        <property name="mapperLocations" value="/WEB-INF/mappers/secondary/*.xml" />
    </bean>

    <!-- Transaction Manager -->
    <bean id="secondaryTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource"><ref bean="secondaryDataSource"/></property>
    </bean>

    <!-- Mapperのスキャン -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="jp.dip.arimodoki.mapper.secondary" />
        <property name="sqlSessionFactoryBeanName" value="secondarySqlSessionFactory" />
    </bean>

</beans>