使用简单的 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 实现的最佳方法是使用 Beans 的 ArrayList 吗?
最佳答案
如果您想跟上多个数据库,这里有一些线索:
无论如何,我会说数据源应该在服务器配置中而不是在应用程序中进行管理。
然后 Mybatis 主配置文件必须放在添加到类路径的位置,但在应用程序包之外,因为每个新数据源都必须在 environment 元素内引用。
对于每个用户请求或 session (如果是 Web 应用程序),将解析配置,因为必须调用 SqlSessionFactoryBuilder.build(reader, environment=NAME);
来选择环境(=> 数据库)。
关于java - MyBatis Spring DYNAMIC 多个数据库的Java配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41813554/