java - 多数据库应用SpringBoot、Hibernate和JPA

标签 java spring hibernate spring-boot spring-data-jpa

我需要一个使用 Spring boot、Hibernate 和 JPA 设计多数据库应用程序的概念。

目前我正在考虑支持 4 个关系数据库(Mysql、H2、SQLLite、Oracle)。

我正在做的是使用 Spring Boot 配置文件功能选择正确的数据库配置文件,然后加载相关的数据库属性。

## application-h2.properties
## Spring DATASOURCE (DataSourceAutoConfiguration & DataSourceProperties)
spring.datasource.url=jdbc:h2:file:~/test
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=
spring.h2.console.enabled=true
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.H2Dialect

# application-mysql.properties
# MySQL-Database
#spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/ntk?autoReconnect=true&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

然后在application.properties中

spring.profiles.active=h2

这里应用程序将运行并加载 h2 数据库的属性。同样,我们可以选择配置文件为 Mysql,它将加载 Mysql 相关属性。

这里,大多数查询都是由 JPA 基于方言生成的。它与所有数据库兼容(因为,我们一次根据所选配置文件为一个数据库运行此应用程序)。但是,我担心的是,如果需要手动编写一些复杂的查询,我如何使其兼容其他数据库。假设某些为 Mysql 设计的查询可能与 Oracle 不兼容。

任何人都可以根据我给出的描述提出一些方法,如果需要其他信息,请告诉我。

最佳答案

鉴于您已经为每个不同的数据库定义了不同的配置文件,为什么不创建一个 bean 来封装所有这些“更高级”的查询并使用 @profile 对其进行注释,以便根据所选的配置文件实际使用正确的配置文件?

创建一个接口(interface),声明一个包含您可能需要的每个高级查询的方法:

public interface IAdvancedQuery {
    void advancedQuery1();
    void advancedQuery2();
     ...  
}

然后,为每个配置文件创建一个实现此接口(interface)的 bean 并对其进行相应的注释:

@Profile("h2")
@Component
public class H2Queries implements IAdvancedQuery {
    @Override
    public void query1() {
        // your h2 specific query goes here
    }
    @Override
    public void query2() {
        ...
    }
    ...
}

@Profile("mysql")
@Component
public class MysqlQueries implements IAdvancedQuery {
    @Override
    public void query1() {
        // your mySQL specific query goes here
    }
    @Override
    public void query2() {
        ...
    }
    ...
}

最后,假设您有一个消费者服务类,您只需使用 @Autowired 注入(inject)适当的 bean,根据您在 spring 应用程序中指定的配置文件自动注入(inject):

@Service
public class ConsumerService {

    @Autowired
    public IAdvancedQuery advancedQuery;

    ...

    public void someMethod() {
       // do something with the advanced query
       advancedQuery.query1();
       ...
    }

    ...
}

最终将根据配置文件和实例化的 bean 选择正确的“高级查询”方法。

关于java - 多数据库应用SpringBoot、Hibernate和JPA,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57433420/

相关文章:

hibernate - EntityManager.merge(x) 导致 "select"查询数据库

java - Hibernate 找不到 hibernate.cfg.xml

java - JMockit 是否初始化 EJB?

java - 如何在 JPA 中保留原始时区

Java RMI 教程 - AccessControlException : access denied (java. io.FilePermission

java - InternalResourceViewResolver 与 UrlBasedViewResolver 有什么不同

java - Spring Boot 2.2.4 - 禁用安全性

spring - 选择 x509 身份验证的客户端证书对话框

java - 与 C# 相比,从 Java 获取错误字节

java - JDBC 连接中的 URL 为空