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

create multiple datasource in spring bean.xml

我正在使用 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

<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>

MySQL

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

用于 Oracle 的 JdbcTemplate

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

希望这能解决您的疑问。