SpringBoot集成H2数据库的实现示例
1. 引言
Spring Boot 以其简洁的配置和快速开发能力,成为现代微服务架构的首选框架之一。而H2数据库作为一个轻量级的内存数据库,非常适合开发阶段作为嵌入式数据库进行单元测试和功能验证。本文将手把手教你如何在Spring Boot项目中集成H2数据库,实现数据的快速存取与管理。
2. H2数据库所需依赖
<dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <scope>compile</scope> </dependency>
3. H2数据库application.yaml配置文件
spring:
datasource:
url: jdbc:h2:~/user
driver-class-name: org.h2.Driver
username: root
password: 123456
h2:
console:
path: /h2-console #h2嵌入式数据库控制台
enabled: true4. 初始化h2数据库
注意:
schema为初始化sql路径
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
import org.springframework.context.ApplicationContext;
import org.springframework.core.io.Resource;
import org.springframework.jdbc.datasource.init.ScriptUtils;
import org.springframework.stereotype.Service;
import javax.annotation.PostConstruct;
import javax.sql.DataSource;
import java.io.File;
/**
* 初始化h2数据库
*/
@Slf4j
@Service
// DataSource创建完后才初始化此类
@AutoConfigureAfter(DataSource.class)
public class H2DataSourceConfig {
//初始化sql
private static final String schema = "classpath:db/schema-h2.sql";
@Autowired
DataSource dataSource;
@Autowired
ApplicationContext applicationContext;
@PostConstruct
public void init() throws Exception {
//初始化本地数据库
String userHome = System.getProperty("user.home");//获取系统用户目录
File f = new File(userHome + File.separator + "h2.lck");
if (!f.exists()) {
log.info("--------------初始化h2数据----------------------");
f.createNewFile();
Resource resource = applicationContext.getResource(schema);
ScriptUtils.executeSqlScript(dataSource.getConnection(), resource);
} else {
log.info("--------------h2数据库已经存在----------------------");
}
}
}5. 初始化sql语句
在resources目录下创建db/schema-h2.sql文件。
DROP TABLE IF EXISTS student;
CREATE TABLE student
(
id BIGINT NOT NULL COMMENT 'id',
name VARCHAR(30) COMMENT '姓名',
age INT COMMENT '年龄',
PRIMARY KEY (id)
);
insert into student(id,name,age) values(1, 'zhangsan',23);
insert into student(id,name,age) values(2, 'lisi',45);
insert into student(id,name,age) values(3, 'wangwu',12);6. 启动项目
访问路径为:http://localhost:8080/h2-console
7. 访问数据库
1. 填写登录信息,如下图所示:

2. 如果有student表,并且有数据,说明数据库配置成功

到此这篇关于SpringBoot集成H2数据库的实现示例的文章就介绍到这了,更多相关SpringBoot集成H2数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
基于Spire.Doc for Java实现HTML转PDF的操作方案
本文记录了使用Spire.DocforJava将HTML内容转换为PDF文档的过程,包括环境准备、两种常见的转换场景、进阶设置以及注意事项,适用于样式复杂度相对可控、排版以文档流为主的转换需求,需要的朋友可以参考下2026-04-04
Spring Boot中捕获异常错误信息并将其保存到数据库中的操作方法
这篇文章主要介绍了Spring Boot中捕获异常错误信息并将其保存到数据库中的操作方法,通过实例代码介绍了使用Spring Data JPA创建一个异常信息的存储库接口,以便将异常信息保存到数据库,需要的朋友可以参考下2023-10-10
mybatis-plus3.0.1枚举返回为null解决办法
这篇文章主要介绍了mybatis-plus3.0.1枚举返回为null解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-12-12


最新评论