1

我正在使用 ObjectDB 在 Spring-Boot 中实现一个程序。为了实际使用 ObjectDB,我遵循了这种非常有效的方法。

但是,一旦我想使用“spring-boot-starter-web”,我就会收到以下错误:

需要 dataSource 或 dataSourceClassName 或 jdbcUrl。在 com.zaxxer.hikari.HikariConfig.validate

正如许多帖子中提到的,我一直在摆弄jdbc-url属性文件中的参数。试图排除Hikari,因为可能ObjectDB使用了他自己的连接池机制。但没有任何结果。

有关如何解决此错误的任何想法?

我正在使用与链接中完全相同的代码。我在 pom 中添加了Spring-Actuator ,如下所示:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
4

2 回答 2

1

在某些情况下,使用 JPA 的框架需要指定 JDBC 连接详细信息,包括 JDBC 驱动程序,然后将其传递给 JPA 实现并由其用于访问数据库。ObjectDB 是一种 JPA 实现,它不访问外部数据库,因此不需要或使用 JDBC 驱动程序。

正如对该问题的评论中所讨论的,一个简单的解决方法是指定一个虚拟 JDBC 驱动程序,该驱动程序将被传递给 ObjectDB,然后被忽略。它看起来确实很奇怪,但在 ObjectDB 实现自己的 JDBC 驱动程序或相关框架在其对 JDBC 驱动程序的请求方面变得更加灵活之前,这是要走的路。

于 2021-02-07T20:49:20.420 回答
0

你试过这个(在pom.xml?):

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
     <dependency>
        <groupId>com.objectdb</groupId>
        <artifactId>objectdb</artifactId>
        <version>2.8.4</version>
    </dependency>

并且不要忘记在以下位置添加数据库连接application.properties

 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
 spring.datasource.username=mydbuser
 spring.datasource.password=mydbpass
 spring.datasource.url=jdbc:....

有关更多详细信息,请参阅https://www.baeldung.com/the-persistence-layer-with-spring-and-jpa

于 2021-02-07T12:50:21.713 回答