考虑一种情况,其中所有客户端数据都存储在其自己的数据库/目录中,并且所有此类数据库都存储在单个RDBMS(客户端数据)中.主数据(例如客户端,……)保存在另一个RDBMS(主数据)中.我们如何通过JdbcTemplate动态访问客户端...
考虑一种情况,其中所有客户端数据都存储在其自己的数据库/目录中,并且所有此类数据库都存储在单个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时动态更改数据库/目录
基础教程推荐
- SpringBoot YAML语法基础详细整理 2023-06-24
- MyBatis后端对数据库进行增删改查等操作实例 2023-03-30
- java实现简单的客户信息管理系统 2022-12-06
- Spring Boot 整合 Reactor实例详解 2023-05-14
- 详解使用JavaMailSender给曾经心爱的她再中秋发送一封特别的邮件 2023-05-14
- swagger文档增强工具knife4j使用图文详解 2022-09-03
- 手动部署java项目到k8s中的实现 2023-04-06
- SpringBoot 整合 Elasticsearch 实现海量级数据搜索功能 2023-03-06
- 图解Java ReentrantLock的条件变量Condition机制 2023-06-11
- java – Mysql流结果集和jOOQ fetchLazy 2023-10-29
