Spring Boot 启动时初始数据库脚本示例

Spring Boot 启动时初始数据库脚本示例

作者:Grey

原文地址:

博客园:Spring Boot 启动时初始数据库脚本示例

CSDN:Spring Boot 启动时初始数据库脚本示例

说明

Spring Boot 在启动时,可以通过 SQL 脚本进行数据库的初始化,以下示例采用 H2 来演示,由于平时学习的时候,涉及到一些连接数据库相关的操作,经常需要初始化本地数据库,比如装个 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


<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.0modelVersion>
    <parent>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-parentartifactId>
        <version>2.3.0.RELEASEversion>
        <relativePath/> 
    parent>
    <groupId>org.huigroupId>
    <artifactId>spring-boot-h2artifactId>
    <version>0.0.1-SNAPSHOTversion>
    <name>spring-boot-h2name>
    <description>Spring Boot for H2description>
    <properties>
        <java.version>1.8java.version>
    properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-jdbcartifactId>
        dependency>
        <dependency>
            <groupId>com.h2databasegroupId>
            <artifactId>h2artifactId>
            <scope>runtimescope>
        dependency>
    dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-maven-pluginartifactId>
            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', '[email protected]'),
   ('jack', '[email protected]');

测试类

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

你可能感兴趣的:(Spring,Spring)