考虑一种情况,其中所有客户端数据都存储在其自己的数据库/目录中,并且所有此类数据库都存储在单个RDBMS(客户端数据)中.主数据(例如客户端,……)保存在另一个RDBMS(主数据)中.我们如何通过JdbcTemplate动态访问客户端数据RDBMS中的特定数据库?
为客户端数据RDBMS中的每个数据库定义DataSource,然后根据建议动态选择一个数据源here不是我们的选项,因为数据库是动态创建和销毁的.
我基本上需要像JDBC的Connection.setCatalog(String目录)这样的东西,但是我没有在Spring JdbcTemplate中找到类似的东西.
最佳答案
也许你可以用
DelegatingDataSource
包装数据源来调用getConnection()中的setCatalog()并在JdbcTemplate创建时使用包装的数据源:
class MyDelegatingDS extends DelegatingDataSource {
private final String catalogName;
public MyDelegatingDS(final String catalogName, final DataSource dataSource) {
super(dataSource);
this.catalogName = catalogName;
}
@Override
public Connection getConnection() throws SQLException {
final Connection cnx = super.getConnection();
cnx.setCatalog(this.catalogName);
return cnx;
}
// maybe also override the other getConnection();
}
// then use like that: new JdbcTemplate(new MyDelegatingDS("catalogName", dataSource));
相关文章
- java - 使用spring jdbctemplate提取数据以加载到不同的数据库中
- 使用spring jdbcTemplate发出REST更新请求时如何验证记录是否存在?
- 如何使线程尝试使用JDBCTemplate重新连接到数据库x次
- 使用Spring JDBCTemplate在数据库中插入新数据记录后如何获取生成的ID?
- 如何使用log4j2在日志文件中记录spring JdbcTemplate sql查询和数据库响应
- java - 使用Spring JdbcTemplate进行多个数据库操作
- java - 使用Spring JdbcTemplate - 注入数据源vs jdbcTemplate
- java - 动态更改Spring数据源