Spring Boot 启动时初始数据库脚本示例
Spring Boot 启动时初始数据库脚本示例
作者:Grey
原文地址:
说明#
Spring Boot 在启动时,可以通过 SQL 脚本进行数据库的初始化,以下示例采用 H2 来演示,由于平时学习的时候,涉及到一些连接数据库相关的操作,经常需要初始化本地数据库,比如装个 MySQL,初始化一些脚本,比较麻烦,H2 是内存数据库,Spring Boot可以在应用启动的时候对H2数据库初始化一些SQL脚本,这样的话,在学习/测试阶段,可以先使用 H2 数据库进行测试和学习,不需要额外安装 MySQL 数据库了。
注意,因为 SQL 脚本是可以在 Spring Boot 启动的时候初始化的,所以,SQL 脚本中可能有一些删表删数据的操作,所以这种操作方式不适合应用在生产数据库。
环境#
-
JDK 21
-
Maven 3.9.5
-
Spring Boot 2.7.17
依赖#
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 http://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.7.17</version>
<relativePath/>
</parent>
<groupId>org.hui</groupId>
<artifactId>spring-boot-h2</artifactId>
<version>1.0.RELEASE</version>
<name>spring-boot-h2</name>
<description>Spring Boot for H2</description>
<properties>
<java.version>21</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
配置文件#
application.properties
spring.datasource.url=jdbc:h2:mem:testdb2
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=
#需要初始化的SQL脚本,指定位置为resources/db目录下,如果不指定,默认就在resources目录下
spring.sql.init.schema-locations=classpath:db/schema.sql
spring.sql.init.data-locations=classpath:db/data.sql
# H2控制台启用
spring.h2.console.enabled=true
# H2访问的URL
spring.h2.console.path=/h2
SQL脚本#
由于配置文件中指定了sql文件的位置,所以以下两个SQL文件放在resources/db目录下,你也可以指定其他目录,见配置文件的注释信息。
schema.sql
DROP TABLE IF EXISTS USER_INFO;
CREATE TABLE USER_INFO (
id INT AUTO_INCREMENT PRIMARY KEY,
user_name VARCHAR(250) NOT NULL,
email VARCHAR(250) DEFAULT NULL
);
data.sql
INSERT INTO
USER_INFO (user_name, email)
VALUES
('grey', 'abc@gmail.com'),
('jack', 'jack@email.com');
测试类#
package org.hui.springbooth2;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.jdbc.core.JdbcTemplate;
/**
* @author zenghui
* @date 2020-5-20
*/
@SpringBootApplication
public class H2Application implements CommandLineRunner {
public static void main(String[] args) {
SpringApplication.run(H2Application.class, args);
}
private final JdbcTemplate template;
public H2Application(JdbcTemplate template) {
this.template = template;
}
@Override
public void run(String... args) {
String sql="SELECT count(*) FROM USER_INFO";
int count = template.queryForObject(sql, Integer.class);
System.out.println("user count is " + count);
}
}
运行#
运行 H2Application.java 这个主类,控制台打印如下信息:
user count is 2
代码#
作者:GreyZeng
出处:https://www.cnblogs.com/greyzeng/p/12923389.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
你可以在这里自定义其他内容
本文来自博客园,作者:Grey Zeng,转载请注明原文链接:https://www.cnblogs.com/greyzeng/p/12923389.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程