Spring H2 驱动程序问题
Posted
技术标签:
【中文标题】Spring H2 驱动程序问题【英文标题】:Spring H2 Driver Issue 【发布时间】:2021-03-31 21:44:53 【问题描述】:我正在尝试运行 CRUD 应用程序,但出现错误
2020-12-22 09:48:40.787 WARN 83274 --- [main] ConfigServletWebServerApplicationContext:上下文初始化期间遇到异常 - 取消刷新尝试:org.springframework.beans.factory.UnsatisfiedDependencyException:创建名为“org”的 bean 时出错.springframework.boot.autoconfigure.orm.jpa.HibernateJpaConfiguration':通过构造函数参数0表示的不满足的依赖关系;嵌套异常是 org.springframework.beans.factory.BeanCreationException:在类路径资源 [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Hikari.class] 中定义名称为“dataSource”的 bean 创建时出错:通过工厂方法进行 Bean 实例化失败;嵌套异常是 org.springframework.beans.BeanInstantiationException:无法实例化 [com.zaxxer.hikari.HikariDataSource]:工厂方法 'dataSource' 抛出异常;嵌套异常是 java.lang.IllegalStateException: Cannot load driver class: org.h2.Driver
我无法连接 H2。它在 application.properties 中以红色输入,如下所示。
这也是我完整的 pom.xml
<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>API</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>API</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
【问题讨论】:
H2 应该开箱即用,我认为您的配置太多。请注意,您的 POM 中有两次 spring-boot-starter-data-jpa。 【参考方案1】:您不需要指定driverClassName
或database-platform
,在您添加h2 依赖项后,Spring 将使用默认值。你需要在依赖项中有mysql-connector-java
吗?
【讨论】:
<scope>runtime</scope>
应该可以正常工作,并且是 start.spring.io 的默认设置。删除除第一行和最后一行之外的所有内容即可。以上是关于Spring H2 驱动程序问题的主要内容,如果未能解决你的问题,请参考以下文章
如何跨多个 Spring Boot 应用程序共享 H2 内存数据库?
无法加载驱动程序类: org.h2.Driver in spring boot
使用 gradle 时,在 Spring Boot 测试期间无法加载驱动程序类:“org.h2.Driver”