在SpringBoot中集成H2数据库的完整指南

 更新时间:2024年10月29日 11:16:30   作者:编码行者  
Spring Boot是一个简化企业级Java应用程序开发的强大框架,H2数据库是一个轻量级的、开源的SQL数据库,非常适合用于开发和测试,本文将指导您如何在Spring Boot应用程序中集成H2数据库,并探索一些高级配置选项,需要的朋友可以参考下

引言

Spring Boot是一个简化企业级Java应用程序开发的强大框架。H2数据库是一个轻量级的、开源的SQL数据库,非常适合用于开发和测试。本文将指导您如何在Spring Boot应用程序中集成H2数据库,并探索一些高级配置选项。

依赖关系

首先,我们需要在项目的pom.xml文件中添加H2数据库和Spring Data JPA的依赖关系:

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

数据库配置

Spring Boot默认配置应用程序连接到一个内存存储的H2数据库,用户名为sa,密码为空。我们可以通过在application.properties文件中添加以下属性来自定义这些设置:

spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=password
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect

或者,我们也可以使用application.yml文件进行配置:

spring:
  datasource:
    url: jdbc:h2:mem:mydb
    username: sa
    password: password
    driverClassName: org.h2.Driver
  jpa:
    database-platform: org.hibernate.dialect.H2Dialect

数据库持久化

默认情况下,H2数据库的内存存储在应用程序重启后会导致数据丢失。为了解决这个问题,我们可以将数据库存储为文件:

spring.datasource.url=jdbc:h2:file:/data/demo

或者在YAML文件中:

spring:
  datasource:
    url: jdbc:h2:file:/data/demo

数据库操作

在Spring Boot中执行CRUD操作与在其他SQL数据库中类似。我们可以使用JPA仓库接口和实体类来管理数据库操作。

初始化数据源

我们可以使用SQL脚本来初始化数据库。在src/main/resources目录下创建一个SQL文件,填充一些示例数据:

INSERT INTO countries (id, name) VALUES (1, 'USA');
INSERT INTO countries (id, name) VALUES (2, 'France');
INSERT INTO countries (id, name) VALUES (3, 'Brazil');
INSERT INTO countries (id, name) VALUES (4, 'Italy');
INSERT INTO countries (id, name) VALUES (5, 'Canada');

Spring Boot会自动运行这个文件来初始化数据库。我们可以通过将spring.sql.init.mode属性设置为never来禁用这种默认行为。此外,还可以配置多个SQL文件来加载初始数据。

Hibernate和data.sql

默认情况下,data.sql脚本在Hibernate初始化之前执行。这使得基于脚本的初始化与Flyway和Liquibase等其他数据库迁移工具保持一致。当我们每次重新创建Hibernate生成的模式时,我们需要设置一个额外的属性:

spring.jpa.defer-datasource-initialization=true

这会修改默认的Spring Boot行为,并在Hibernate生成模式之后填充数据。

访问H2控制台

H2提供了一个嵌入式的GUI控制台,用于浏览数据库内容和运行SQL查询。要启用H2控制台,在application.properties中添加以下属性:

spring.h2.console.enabled=true

或者在application.yml中:

spring:
  h2:
    console:
      enabled: true

启动应用程序后,访问http://localhost:8080/h2-console即可使用H2控制台。在登录页面使用配置的数据库URL和凭据进行登录。

进一步配置H2控制台

我们可以通过在项目的application.properties中指定以下属性来进一步配置控制台:

spring.h2.console.path=/h2-console
spring.h2.console.settings.trace=false
spring.h2.console.settings.web-allow-others=false

或者在YAML配置中:

spring:
  h2:
    console:
      path: /h2-console
      settings:
        trace: false
        web-allow-others: false

H2数据库URL选项

H2数据库URL提供了多种选项以进一步自定义数据库行为。例如:

  • DB_CLOSE_DELAY=-1:确保在JVM运行期间数据库保持打开状态。
  • DB_CLOSE_ON_EXIT=FALSE:即使JVM关闭,数据库也保持打开状态。
  • AUTO_RECONNECT=TRUE:允许在连接丢失时自动重新连接。
  • MODE=PostgreSQL:将H2数据库设置为PostgreSQL兼容模式。

示例配置:

spring.datasource.url=jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE;AUTO_RECONNECT=TRUE;MODE=PostgreSQL;

结论

H2数据库与Spring Boot的集成非常流畅,提供了一个轻量级且功能丰富的解决方案,非常适合开发和测试。通过本文的指南,您应该能够轻松地在Spring Boot应用程序中集成H2数据库,并利用其强大的功能。

以上就是在SpringBoot中集成H2数据库的完整指南的详细内容,更多关于SpringBoot集成H2数据库的资料请关注脚本之家其它相关文章!

相关文章

  • Springboot集成定时器和多线程异步处理操作

    Springboot集成定时器和多线程异步处理操作

    这篇文章主要介绍了Springboot集成定时器和多线程异步处理操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Java 判断IP地址的合法性实例详解

    Java 判断IP地址的合法性实例详解

    这篇文章主要介绍了Java 判断IP地址的合法性实例详解的相关资料,需要的朋友可以参考下
    2017-05-05
  • 基于Java网络编程和多线程的多对多聊天系统

    基于Java网络编程和多线程的多对多聊天系统

    这篇文章主要介绍了基于Java网络编程和多线程的多对多聊天系统,文中有非常详细的代码示例,对正在学习java网络编程的小伙伴们有非常好的帮助,需要的朋友可以参考下
    2021-04-04
  • Shiro实现session限制登录数量踢人下线功能

    Shiro实现session限制登录数量踢人下线功能

    这篇文章主要介绍了Shiro实现session限制登录数量踢人下线,本文记录的是shiro采用session作为登录方案时,对用户进行限制数量登录,以及剔除下线,需要的朋友可以参考下
    2023-11-11
  • Java 中导入excel时使用 trim() 无法去除空格的问题解决方案

    Java 中导入excel时使用 trim() 无法去除空格的问题解决方案

    这篇文章主要介绍了Java中导入excel时使用trim()无法去除空格的解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • SpringBoot集成使用Redis及搭建过程

    SpringBoot集成使用Redis及搭建过程

    jackson-json 工具提供了 javabean 与 json 之 间的转换能力,可以将 pojo 实例序列化成 json 格式存储在 redis 中,也可以将 json 格式的数据转换成 pojo 实例,本文给大家介绍SpringBoot集成使用Redis及搭建过程,感兴趣的朋友一起看看吧
    2022-01-01
  • Java代理深入讲解之静态代理

    Java代理深入讲解之静态代理

    这篇文章主要给大家介绍了关于Java静态代理的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Java 读取、获取配置文件.properties中的数据

    Java 读取、获取配置文件.properties中的数据

    这篇文章主要介绍了Java 读取、获取配置文件.properties中的数据,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • Java Collections工具类中常用算法解析

    Java Collections工具类中常用算法解析

    在软件开发中,算法是非常重要的一部分,它们可以提供高效的数据处理和操作,这篇文章主要为大家介绍了Collections 工具类集合框架中常用算法,感兴趣的可以了解一下
    2023-06-06
  • springboot启动脚本start.sh和停止脚本 stop.sh的详细教程

    springboot启动脚本start.sh和停止脚本 stop.sh的详细教程

    这篇文章主要介绍了springboot启动脚本start.sh和停止脚本 stop.sh的详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08

最新评论