1. 概述

  1. 之前讲到了 H2 的引入
  2. 这下我想说说 H2 启动时的 数据导入

2. 场景

  1. 需求

    1. 启动项目后, H2 启动起来
    2. 环境数据会自动注入 H2 数据库
    3. 可以验证是否成功

3. 环境

  1. os

    1. win10
  2. jdk

    1. 1.8
  3. ide

    1. ida 2018.1
  4. spring

    1. spring boot

      1. 2.1.7 release
    2. 组件
      1. thymeleaf
      2. starter-web
      3. devtool
      4. starter-test
  5. browser

    1. firefox

      1. 70.0
  6. H2

    1. 1.4.197
  7. ref

    1. spring in action 5th

4. 步骤

1. 准备好 sql 文件

  1. schema.sql

    1. create table if not exists Ingredient (
    2. id varchar(4) not null,
    3. name varchar(25) not null,
    4. type varchar(10) not null
    5. );
  2. data.sql

    1. delete from Ingredient;
    2. insert into Ingredient (id, name, type)
    3. values ('FLTO', 'Flour Tortilla', 'WRAP');

2. 配置

  1. 概述

    1. 配置 H2 相关的 sql 配置
  2. 前提

    1. 上一篇博文写到的配置, 已经配好了
    2. 这次只给出 增量
    3. application.properties
  3. 内容

    1. # H2: 写入数据
    2. spring.datasource.url=jdbc:h2:mem:test_db
    3. spring.datasource.driverClassName=org.h2.Driver
    4. spring.datasource.username=sa
    5. spring.datasource.password=sa
    6. #spring.datasource.schema=classpath:schema.sql
    7. #spring.datasource.data=classpath:data.sql
  4. 解释

    1. url

      1. 内存数据库
      2. 最后的 库名, 可以自己起
        1. 老实说, 我也没弄清这块的规则, 但是现在能用
    2. driverClassName

      1. 驱动类
    3. username & password

      1. 默认值
    4. schema & data

      1. 启动时默认执行的 sql 文件
      2. 默认位置
        1. resources 目录下
        2. 这个 path 可以改, 文件名也可以改
      3. 默认顺序
        1. schema
        2. data

3. 验证

  1. 概述

    1. 配置好后, 验证一下即可

1. 步骤

  1. 重启项目

  2. 进入 浏览器 console

    1. url

      1. localhost:8080/console
  3. 登录

    1. jdbc url

      1. # 和 之前的配置一样就行
      2. jdbc:h2:mem:test_db
    2. username & password

      1. sa/sa
  4. 验证

    1. 确认表在
    2. 查看数据是否一致

ps

  1. ref

    1. SpringBoot整合系列-整合H2
  2. 其他

    1. 暴露了 sql 只是的贫乏
    2. H2 总算起来了, 可以继续往下走了

Spring - 周边设施 - H2 数据库启动时写入数据的更多相关文章

  1. Spring - 周边设施 - H2 embedded 版本引入

    1. 概述 在 Spring 开发中, 引入 H2 做辅助测试数据库 2. 场景 复习 Spring, 复习到 持久化 部分 需要一个 数据库 来做测试 方案 方案1: 搭建 MySQL 实例 虽然现 ...

  2. Oracle-11g 数据库启动时,报错"ORA-01092"及"ORA-18008: cannot find OUTLN schema"

    适用情形: Oracle-11g 数据库启动时,出现类似如下错误. ORA-01092: ORACLE instance terminated. Disconnection forced ORA-18 ...

  3. Spring Boot 2 (七):Spring Boot 如何解决项目启动时初始化资源

    Spring Boot 2 (七):Spring Boot 如何解决项目启动时初始化资源 在项目启动的时候需要做一些初始化的操作,比如初始化线程池,提前加载好加密证书等.今天就给大家介绍一个 Spri ...

  4. spring boot整合H2数据库

    一.背景: .H2数据库是一个开源的关系型数据库.H2是一个嵌入式数据库引擎,采用java语言编写,不受 平台的限制,同时支持网络版和嵌入式版本,有比较好的兼容性,支持相当标准的sql标准,支持集群. ...

  5. Spring Boot集成H2数据库

    需求 平时学习的时候,涉及到一些连接数据库相关的操作,经常需要初始化本地数据库,比如装个MySQL,初始化一些脚本,比较麻烦,H2是内存数据库,Spring Boot可以在应用启动的时候对H2数据库初 ...

  6. 2018-08-24 中文代码之Spring Boot对H2数据库简单查询

    续前文: 中文代码之Spring Boot集成H2内存数据库 在词条中添加英文术语域: @Entity public class 词条 { @Id private long id; private S ...

  7. Spring单元测试集成H2数据库

    项目源代码在:Spring-H2测试 H2简介 H2数据库是一种由Java编写的,极小,速度极快,可嵌入式的数据库.非常适合用在单元测试等数据不需要保存的场景下面. 以下时其官网的介绍: {% blo ...

  8. SpringBoot 源码解析 (三)----- Spring Boot 精髓:启动时初始化数据

    在我们用 springboot 搭建项目的时候,有时候会碰到在项目启动时初始化一些操作的需求 ,针对这种需求 spring boot为我们提供了以下几种方案供我们选择: ApplicationRunn ...

  9. windows xp 创建 Oracle(11G)数据库实例时写入系统日志失败解决方案

    1.查看Windows日志相关服务(Even Log),无异常: 2.清空事件管理器中“应用程序”和“系统节点”的内容,对这两个节点,分别在“属性”页面用增大“最大日志文件大小”的值,并选中“按需要改 ...

随机推荐

  1. 微信小程序判断input是否为空

    微信小程序中用到input值时候,判断其内容是否为空,可以用if-else判断内容的length,也可以给input加点击事件,判断其内容:以下是我解决问题的过程wxml代码 <view cla ...

  2. mybatis一级缓存和二级缓存(一)

    一级缓存: 就是Session级别的缓存.一个Session做了一个查询操作,它会把这个操作的结果放在一级缓存中. 如果短时间内这个session(一定要同一个session)又做了同一个操作,那么h ...

  3. C++面向对象编程实例

    实例一.四位运算符操作 main.cpp. #include <iostream> #include "operator_1.h" #include <stdio ...

  4. mac或windows下Navicat Premium安装

    找了很多地址都乱七八糟的说明一通还没啥用,好不容易找到一个靠谱的,记录一下,也方便一下和我一样苦苦寻找的人,亲测有用 https://www.52pojie.cn/thread-727433-1-1. ...

  5. STL-priority_queue H - 看病要排队

    H - 看病要排队 看病要排队这个是地球人都知道的常识.不过经过细心的0068的观察,他发现了医院里排队还是有讲究的.0068所去的医院有三个医生(汗,这么少)同时看病.而看病的人病情有轻重,所以不能 ...

  6. 《深入理解Java虚拟机》读书笔记三

    第四章 虚拟机性能监控与故障处理工具 1.JDK命令行工具 jps命令: 作用:列出正在运行的虚拟机进程. 格式:jps [option] [hostid] 选项:-q 只输出LVMID(Local ...

  7. vue组件引入

    /src/route/index.js import Demo2 from '@/pages/demo2/index.vue' { path : '/demo2', name : 'demo2', c ...

  8. 极客工具,PDF合并工具

    前言 这两天一番花两天的时间,重新用python和python图形化开发工具tkinter,完善了下PDF合并小工具,终于可以发布了. 工具目前基本功能已经完善,后期如果有反馈可以修复部分bug或完善 ...

  9. 第四十四篇 入门机器学习——matplotlib基础——实现数据可视化

    No.1. 绘制一条正弦曲线 No.2. 在一张图中绘制多条曲线 No.3. 可以为曲线指定颜色.线条样式 No.4. 可以指定横纵坐标轴的范围 也可以使用: No.6. 可以为每条曲线添加图示 No ...

  10. c#解析json字符串处理

    本文链接:https://blog.csdn.net/sajiazaici/article/details/77647625本文是全网第二简单的方法,因为我女票也发了一篇博客说是全网最简单的方法,我不 ...