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】:

您不需要指定driverClassNamedatabase-platform,在您添加h2 依赖项后,Spring 将使用默认值。你需要在依赖项中有mysql-connector-java吗?

【讨论】:

&lt;scope&gt;runtime&lt;/scope&gt; 应该可以正常工作,并且是 start.spring.io 的默认设置。删除除第一行和最后一行之外的所有内容即可。

以上是关于Spring H2 驱动程序问题的主要内容,如果未能解决你的问题,请参考以下文章

如何跨多个 Spring Boot 应用程序共享 H2 内存数据库?

无法加载驱动程序类: org.h2.Driver in spring boot

使用 gradle 时,在 Spring Boot 测试期间无法加载驱动程序类:“org.h2.Driver”

无法在 Spring 应用程序中登录 H2 控制台

Spring Boot 应用程序中的 H2 Schema 为空

如何从另一个 Spring Boot 应用程序访问一个 Spring Boot 应用程序的内存 H2 数据库