MyBatis Spring DYNAMIC 多数据库数 Java 配置

MyBatis Spring DYNAMIC number of multiple databases Java configuration

使用简单的 Spring DAO 方法,这是相当直接的。但是,使用 MyBatis,有没有办法设置多个潜在的数据源?

我能想到的最佳方法是使用每个包含 datasource.driverclass、datasource.url、datasource.username、datasource.password 等的 Bean 的 ArraList

数据源的值存储在单独的属性文件中。这些 属性 个文件(或更多)可能有 1 个或 10 个。

因此,例如,一个应用程序启动时,所有 属性 文件将一次一个地加载到 ArrayList 中。然后,根据 属性 文件中的 NAME=value 行,我们将知道要命中哪个数据源。

所以http:localhost:8080/name=db1

... 将访问配置为名称“09”的数据源中的所有数据。每个 属性 文件将包含:

name=db1
datasource.driverclass=jdbc:sqlserver
datasource.url=jdbc:sqlserver://localhost:1433;databaseName=someDBname
datasource.username=user1
datasource.password=pass1

所以这里的标识符是"name=db1".

MyBatis 实现的最佳方法是使用 ArrayList of Beans 吗?

如果您想跟上多个数据库,这里有一些线索:

无论如何,我会说数据源应该在服务器配置中而不是在应用程序中进行管理。

然后Mybatis主配置文件必须放在添加到类路径的位置,但在应用程序包之外,因为每个新数据源都必须在environment元素内引用.

并且对于每个用户请求或会话(在网络应用程序的情况下),配置将被解析,因为必须调用 SqlSessionFactoryBuilder.build(reader, environment=NAME); 来选择环境(=> 数据库)。

我最终使用了分层 application.yml 文件,该文件根据选定的租户代码详细说明了多租户连接值。