在spring bean.xml中创建多个数据源

时间:2018-04-03 05:18:31

标签: spring datasource jdbctemplate

我正在使用Spring jdbctemplate。想在bean.xml中创建多个数据源。

下面是我如何在bean.xml中创建单个数据源的详细信息。

<bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />

<property name="username" value="xxx" />
<property name="url" value="jdbc:mysql://localhost:3306/test" />
<property name="password" value="yyy"/>

<!-- Definition for JDBCTemplate bean -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSource"></property>
</bean>

现在我想用不同的数据库添加另一个数据源。我如何在bean.xml中执行此操作。

请不要给我替代品。首先要说明是否可能。如果可能的话怎么做。

1 个答案:

答案 0 :(得分:1)

定义datasource-1

<bean name="mysqlDatasource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/test" />
    <property name="username" value="xxx" />
    <property name="password" value="yyy" />
</bean>

同样,定义datasource-2

<bean id="oracleDatasource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
  <property name="url" value="jdbc:oracle:thin:@localhost:1521:test"/>
  <property name="username" value="oracle_user"/>
  <property name="password" value="oracle_password"/>
</bean>

JdbcTemplate for MySQL

<bean id="mysqlJdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="mysqlDatasource"/>
</bean>

JdbcTemplate for Oracle

<bean id="oracleJdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="oracleDatasource"/>
</bean>

希望这会清除您的查询。