上一篇博文介绍如何使用spring.datasource来实现项目启动之后的数据库初始化,本文作为数据库初始化的第二篇,将主要介绍一下,如何使用spring.jpa的配置方式来实现相同的效果

I. 项目搭建

1. 依赖

首先搭建一个标准的SpringBoot项目工程,相关版本以及依赖如下

本项目借助SpringBoot 2.2.1.RELEASE + maven 3.5.3 + IDEA进行开发

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency>
</dependencies>
复制代码

本文使用MySql数据库, 版本8.0.31

2. 配置

注意实现初始化数据库表操作的核心配置就在下面,重点关注

配置文件: resources/application.yml

# 默认的数据库名
database:name: storyspring:datasource:url: jdbc:mysql://127.0.0.1:3306/${database.name}?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghaiusername: rootpassword:initialization-mode: alwaysjpa:show-sql: truegenerate-ddl: truehibernate:ddl-auto: update # 取值create/create-drop时,会根据Entity生成表之后,再使用import.sql文件导入初始化数据; 为update时,则执行的是 data.sql logging:level:root: infoorg:springframework:jdbc:core: debug
复制代码

注意上面jpa的一个配置,其次就是上一篇博文中介绍的 spring.datasource.initialization-mode 同样需要将配置设置为 always

使用jpa的配置方式,将ddl-auto设置为create或者create-drop时,会自动搜索@Entity实体对象,并创建为对应的表

II. 示例

1. 验证demo

接下来上面的工作准备完毕之后,我们先创建一个实体对象

@Data
@DynamicUpdate
@DynamicInsert
@Entity
@Table(name = "user3")
public class User {@Id@Column(name = "id")private Long id;@Column(name = "third_account_id")private String thirdAccountId;@Column(name = "user_name")private String userName;@Column(name = "password")private String password;@Column(name = "login_type")private Integer loginType;@Column(name = "deleted")private Integer deleted;@Column(name = "create_time")private Timestamp createTime;@Column(name = "update_time")private Timestamp updateTime;
}
复制代码

接下来我们的目标就是基于上面这个实体类生成对应的表结构

@Slf4j
@SpringBootApplication
public class Application implements ApplicationRunner {@Autowiredprivate JdbcTemplate jdbcTemplate;public static void main(String[] args) {SpringApplication.run(Application.class);}@Overridepublic void run(ApplicationArguments args) throws Exception {List list = jdbcTemplate.queryForList("select * from user3 limit 2");log.info("启动成功,初始化数据: {}\n{}", list.size(), list);}
}
复制代码

直接启动项目之后,到数据库中将可以查到已经创建了一个库user3

2. 初始化数据

上面的过程只是初始化了表结构,如果我们希望导入一些初始化数据,可以怎么办?

如上面的配置: spring.jpa.hibernate.ddl-auto: update,此时在资源目录下,新建 data.sql , 取值为

INSERT INTO `user3` (id, third_account_id, `user_name`, `password`, login_type, deleted)
VALUES (3, '333333-0f85-4dd5-845c-7c5df3746e92', 'data', 'data', 0, 0);
复制代码

然后再次执行,既可以看到db中会新增一条数据

spring.jpa.hibernate.ddl-auto: create,则再资源目录下,新建import.sql文件,来实现数据初始化

3. 小结

使用Jpa的配置方式,总体来说和前面的介绍的spring.datasource的配置方式差别不大,jpa方式主要是基于@Entity来创建对应的表结构,且不会出现再次启动之后重复建表导致异常的问题(注意如上面data.sql中的数据插入依然会重复执行,会导致主键插入冲突)

本文中需要重点关注的几个配置:

  • spring.datasource.initialization-mode: always 同样需要设置为always
  • spring.jpa.generate-ddl: true 会根据@Entity注解的实体类生成对应数据表
  • spring.jpa.hibernate.ddl-auto: create/create-drop 这两个取值时,再创建表之后执行import.sql文件导入测试数据;若取值为update,则会执行data.sql

SpringBoot系列之数据库初始化-jpa配置方式相关推荐

  1. SpringBoot—数据库初始化脚本配置

    关注微信公众号:CodingTechWork,一起学习进步. 介绍 在SpringBoot工程中,一般情况下,我们通过jpa或者mybatis自动生成表后,下次重启后就不会再重新生成表.但也不可避免会 ...

  2. 学习ASP.NET Core Razor 编程系列六——数据库初始化

    学习ASP.NET Core Razor 编程系列目录 学习ASP.NET Core Razor 编程系列一 学习ASP.NET Core Razor 编程系列二--添加一个实体 学习ASP.NET ...

  3. springboot之jackson的两种配置方式

    springboot 针对jackson是自动化配置的,如果需要修改,有两种方式: 方式一:通过application.yml 配置属性说明:## spring.jackson.date-format ...

  4. Springboot集成Quartz定时任务yml文件配置方式

    构建maven项目,引入maven依赖包 其中quartz.quartz-jobs.spring-boot-starter-quartz.spring-context-support  四个依赖包为q ...

  5. springboot jpa 配置多数据源报错解决 Consider defining a bean named ‘entityManagerFactory‘

    版本 springboot 2.6.x 现象 jpa配置多数据源后启动报错 Consider defining a bean named 'entityManagerFactory' 解决 方法1:将 ...

  6. java 数据库连接池配置方式

    一,Tomcat配置数据源: 方式一:在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,内容如下:  <Context>       <Resour ...

  7. 用SpringBoot整合ES数据库基础

    一.SpringBoot整合ES数据库 1.配置原生的依赖. <properties><java.version>1.8</java.version><!-- ...

  8. Springboot 系列(十)使用 Spring data jpa 访问数据库

    前言 Springboot data jpa 和 Spring jdbc 同属于 Spring开源组织,在 Spring jdbc 之后又开发了持久层框架,很明显 Spring data jpa 相对 ...

  9. SpringBoot JPA 配置多个数据库

    SpringBoot JPA 配置多个数据库 一.application.yml : 二.创建一个SpringBoot配置类 三.primary数据源的JPA配置 四.secondary数据源的JPA ...

最新文章

  1. 七 递归与二分法、匿名函数、内置函数
  2. WINCE注册表应用
  3. 利用Hadoop Streaming处理二进制格式文件
  4. AS打开速度慢,AS项目导入慢,新建项目导入慢
  5. jwt判断token是否过期_前端也得搞懂 JWT 这个知识点
  6. [恢]hdu 1865
  7. java date传输类型错误_转换日期格式:Java中的转换错误?
  8. 【自动化】Python3+Selenium3自动化测试-准备工作
  9. Window服务器可安装的live messager最新版本-20090826
  10. 浮动元素与兄弟之间的关系 速记 1211
  11. 升降摄像头设计!realme X今日亮相:现已在多平台开启预约
  12. Codeforces Beta Round #71 C【KMP+DP】
  13. UVA11393 Tri-Isomorphism【数学推理】
  14. DUILIB相对位置修改为锚概念
  15. 一些情况及问题的说明
  16. 计算机网络知识点之五
  17. 存储器之主存--Cache--辅存大全
  18. Godot Engine:选择Skeleton节点时出现不停输出“object was deleted while awaiting a callback”并死机问题
  19. 英语字根(转)--推荐
  20. 独家:微贷网上市细节曝光!2018年上半年净利达3.63亿

热门文章

  1. 微信小程序下拉刷新真机没效果_微信小程序 下拉刷新 上拉加载(示例代码)
  2. Nginx中的长连接
  3. Logistic 分类器与 softmax分类器
  4. 【设计模式】--- 装饰器模式、静态代理模式和动态代理模式
  5. MSSQL 系统函数
  6. 微信公众号发送模板消息,发送消息到某个用户
  7. 2020年 网络 “十大热词” 出炉,你熟悉哪些?
  8. cdn与gnd接地_接地-和接地相关的内容-阿里云开发者社区
  9. SOT23-6封装 小封装 超精简外围PD Sink端取电协议芯片
  10. c语言坐标打符号,c语言中特殊符号