使用 Hikari CP 实例化 H2 时出错

Error while instantiating H2 with Hikari CP

我正在尝试使用 spring 引导将 H2 设置为我的测试环境的内存数据库。我已将我的应用程序配置为:

spring.datasource.url=jdbc:h2:mem:test
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.platform=postgres

spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL9Dialect
spring.jpa.database=POSTGRESQL
spring.jpa.show-sql=false
spring.datasource.driverClassName=org.postgresql.Driver

但是我收到这个错误: 通过工厂方法实例化 Bean 失败;嵌套异常是 org.springframework.beans.BeanInstantiationException:无法实例化 [javax.sql.DataSource]:工厂方法 'dataSource' 抛出异常;嵌套异常是 java.lang.RuntimeException:驱动程序 org.postgresql.Driver 声称不接受 jdbcUrl,jdbc:h2:mem:test

我使用的是 Hikari 3.2.0 版。

您使用了 postgresql 配置。下面是 hikari 和 H2 的配置

spring.datasource.type=com.zaxxer.hikari.HikariDataSource
spring.datasource.url=jdbc:h2:mem:test
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect
spring.jpa.database=h2
spring.datasource.username=sa
spring.datasource.password=

按照 HikariCP or specific answer from forum 使用不同的驱动程序定义 H2 数据库:

 org.h2.jdbcx.JdbcDataSource