需求

平时学习的时候,涉及到一些连接数据库相关的操作,经常需要初始化本地数据库,比如装个MySQL,初始化一些脚本,比较麻烦,H2是内存数据库,Spring Boot可以在应用启动的时候对H2数据库初始化一些SQL脚本,这样的话,在学习/测试阶段,可以先使用H2数据库进行测试和学习,不需要额外安装MySQL数据库了。

注意

因为SQL脚本是可以在Spring Boot启动的时候初始化的,所以,假如你的SQL脚本中有一些删表删数据的操作,所以这种操作方式不适合应用在生产数据库。

环境

  • JDK 1.8
  • Maven 3.6.1
  • Spring Boot 2.3.0.RELEASE

依赖

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.3.0.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>org.hui</groupId>
<artifactId>spring-boot-h2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>spring-boot-h2</name>
<description>Spring Boot for H2</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<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.datasource.schema=classpath:db/schema.sql
spring.datasource.data=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

代码

Github

Gitee

最新文章

  1. MyEclipse建立SpringMVC入门HelloWorld项目
  2. innerHeight,clientHeight,offsetHeight,scrollWidth等的区别和用法
  3. mysql安装方法
  4. easyui datagrid使用(好)
  5. 50. Pow(x, n) (编程技巧)
  6. SuperSlidev2.1 轮播图片和无缝滚动
  7. 玩转createjs
  8. 初识chromium thread的实现
  9. 多模块分布式系统的简单服务访问 - OSGI原形(.NET)
  10. 笨方法学python--读写文件
  11. mysql中不等于过滤null的问题
  12. c语言程序设计第3周编程作业(数字特征)
  13. KNN算法的代码实现
  14. 断路器Ribbon
  15. JavaScript术语:shim 和 polyfill
  16. [转] BootStrap table增加一列显示序号
  17. vue中的axios
  18. 在同一个Linux上配置多个git账户
  19. Collection List接口
  20. user\db\table_privs\column_privs四张表的权限控制

热门文章

  1. IBM WebSphere 远程代码执行漏洞安全预警通告
  2. js 实现动画功能,完整解析插件版 可更改配置参数[animate.js]
  3. 2018 ICPC Pacific Northwest Regional Contest I-Inversions 题解
  4. nmcli的基本使用
  5. Pointers and Memory
  6. mock 处理接口依赖
  7. 禅道部署(基于 Linux)
  8. nginx常见应用实例
  9. 使用Python实现批量ping操作
  10. C. Game with Chips(陷阱暴力题)