在springbean.xml中创建多个数据源

在springbean.xml中创建多个数据源,spring,datasource,jdbctemplate,Spring,Datasource,Jdbctemplate,我使用的是SpringJDBCTemplate。希望在bean.xml中创建多个数据源 <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="username"

我使用的是SpringJDBCTemplate。希望在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中创建单个数据源的详细信息

<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中实现它

<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>
请不要给我其他选择。首先告诉我这是否可能。如果可能,如何操作。

定义数据源-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的jdbc模板

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

用于Oracle的JDBC模板

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


希望这能清除您的查询。

与第一次查询相同。只需以不同的方式命名bean的id即可。@Avinashana我如何知道哪个id映射到哪个数据库?数据源可以定义为包含所有db特定属性的bean,如db url、用户名、密码和驱动程序。停止胆小鬼的行为,有勇气添加注释。