SpringBoot自动初始化数据库的方法分享

 更新时间:2023年08月23日 14:05:50   作者:哒哒哒打代码  
我们在项目中应该经常遇到过初始化数据的场景,特别是项目部署或者交付的时候,那么有什么方式可以在项目启动的时候自动初始化数据库呢,下面小编就来和大家分享几个方法吧

前言

我们在项目中应该经常遇到过初始化数据的场景,特别是项目部署或者交付的时候,需要建表、初始化数据等,那我们一般可能在部署前,提前在DB中执行SQL,那么有什么方式可以在项目启动的时候自动初始化数据库呢?SpringBoot为我们提供了几种快捷的方式。

JPA映射初始化

如果我们在项目中用到了jpa,那就初始化数据库表结构就比较简单,因为我们的类就关联的表名和字段,我们可以通过配置:

spring.jpa.generate-ddl = true

来开启自动生成DDL,又或者直接指定hibernate配置:

# none:不处理
# validate:只校验表是否和实体类对应
# update:更新表结构,但是它只会新增,不会删除
# create:先drop再创建
# create-drop:和create不同的是应用关闭时会drop表,一般会在单元测试时使用
spring.jpa.hibernate.ddl-auto = none / validate / update / create / create-drop

spring.jpa.hibernate.ddl-auto的默认值是变化的,如果我们用了内嵌数据库,那么默认值是create-drop,如果没有,那么就是none,即不做任何操作。

如果我们指定了spring.jpa.hibernate.ddl-auto那么就没有必要再使用spring.jpa.generate-ddl了,不要混用两个配置。

初始化脚本

上面所说的数据库初始化依赖于我们的ORM框架,而且它只能初始化表结构,如果有数据需要初始化就无法实现了,SpringBoot也考虑到了这一点,因此我们还可以能过初始化脚本来进行数据库初始化,比如我们定义一个SQL脚本如下:

CREATE TABLE IF NOT EXISTS t_user
(
    id bigint auto_increment primary key comment 'id',
    name        varchar(64)  default '' not null comment '姓名',
    age         int          default 0    not null comment '年龄',
    description varchar(128) default ''   not null comment '描述',
)
COMMENT '用户';
-- 插入默认用户
INSERT IGNORE INTO t_user (name, age, description) VALUES ('admin', 10, '');

脚本名称为:schema-mysql.sql,那么我们就可以通过配置来在项目启动时,自动执行上面的SQL脚本:

# 指定对应的数据库平台,可以取值all或者指定的平台
spring.sql.init.platform = mysql
# 指定SQL初始化模式,取值always / never / embedded 
# embedded则是只在使用嵌入式DB时才执行
# 如果不需要执行初始化脚本,那么可以设置值为 never
spring.sql.init.mode = always

SpringBoot在启动时,会自动在classpath下寻找schema-${platform}.sqldata-${platform}.sql文件并执行。

@Sql注解

这种方式只能用于单元测试,在单元测试时通过@Sql注解来指定测试前后需要执行的脚本,具体可以查看:《SpringBoot单元测试实践——数据隔离篇》

总结

上面介绍了几种SpringBoot中在项目运行前初始化数据库的方式,那么我们在实际生产环境中会使用吗?我的回答是看场景:

  • 一般情况下,不会使用,因为如果是一个长期运行的服务,除了第一次部署需要初始化,后续更多的是表结构的变更,比如增加、删除字段,那么对于这种操作,是比较谨慎的,特别是大表,更多的是采用在线改表的方式进行。
  • 但是对于一些特定的场景还是有价值的,比如乙方的项目交付,我一个项目可能需要交付给很多地方,而且后续也没什么变更,那么通过这种方式可以简化部署流程。
  • 还有一种场景是边缘部署,可能我们的项目需要在边缘侧部署,可能部署的数量也非常多,且是持续的,那么使用这种方式也可以提升效率,简化流程。

到此这篇关于SpringBoot自动初始化数据库的方法分享的文章就介绍到这了,更多相关SpringBoot初始化数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringCloud修改Feign日志记录级别过程浅析

    SpringCloud修改Feign日志记录级别过程浅析

    OpenFeign源于Netflix的Feign,是http通信的客户端。屏蔽了网络通信的细节,直接面向接口的方式开发,让开发者感知不到网络通信细节。所有远程调用,都像调用本地方法一样完成
    2023-02-02
  • SpringBoot防止消息重复消费的方法步骤

    SpringBoot防止消息重复消费的方法步骤

    这段文章详细介绍了消息队列中消息重复消费的问题及解决方案,重点讲解了Redis唯一ID防重、数据库唯一索引防重、业务状态机防重和全局唯一约束防重四种方案,适合不同业务场景和并发量的需求,需要的朋友可以参考下
    2026-05-05
  • Java中的@Repeatable注解的作用详解

    Java中的@Repeatable注解的作用详解

    这篇文章主要介绍了Java中的@Repeatable注解的作用详解,@Repeatable注解是用来标注一个注解在同一个地方可重复使用的一个注解,使被他注释的注解可以在同一个地方重复使用,需要的朋友可以参考下
    2024-01-01
  • jar包中替换指定的class文件方法详解

    jar包中替换指定的class文件方法详解

    这篇文章主要为大家介绍了jar包中替换指定的class文件方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • idea注解参数换行时间日期格式设置方法

    idea注解参数换行时间日期格式设置方法

    这篇文章主要介绍了idea注解参数换行时间日期格式设置方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • Java包装类与异常处理的过程

    Java包装类与异常处理的过程

    本文介绍了Java中包装类和异常处理的概念,解析了它们的用途和使用方法,包装类主要用于将基本数据类型转换为对象,解决面向对象编程中的限制;异常处理机制则帮助程序优雅地处理运行时错误,包括常见异常类型、异常处理语句及自定义异常的使用
    2026-04-04
  • windows系统使用mvn命令打包并指定jdk路径方式

    windows系统使用mvn命令打包并指定jdk路径方式

    这篇文章主要介绍了windows系统使用mvn命令打包并指定jdk路径方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Java生成随机数的方法

    Java生成随机数的方法

    本篇文章主要介绍了Java生成随机数的方法,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-05-05
  • Spring boot配置文件加解密详解

    Spring boot配置文件加解密详解

    这篇文章主要给大家介绍了关于Spring boot配置文件加解密的相关资料,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • java统计文件中每个字符出现的个数

    java统计文件中每个字符出现的个数

    这篇文章主要为大家详细介绍了java统计文件中每个字符出现的个数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03

最新评论