前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot系列之数据库初始化-jpa配置方式

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

作者头像
一灰灰blog
发布2022-12-29 14:54:13
1K0
发布2022-12-29 14:54:13
举报
文章被收录于专栏:小灰灰

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

<!-- more -->

I. 项目搭建

1. 依赖

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

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

代码语言:javascript
复制
<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

代码语言:javascript
复制
# 默认的数据库名
database:
  name: story

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/${database.name}?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password:
    initialization-mode: always

  jpa:
    show-sql: true
    generate-ddl: true
    hibernate:
      ddl-auto: update # 取值create/create-drop时,会根据Entity生成表之后,再使用import.sql文件导入初始化数据; 为update时,则执行的是 data.sql 

logging:
  level:
    root: info
    org:
      springframework:
        jdbc:
          core: debug

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

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

II. 示例

1. 验证demo

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

代码语言:javascript
复制
@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;
}

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

代码语言:javascript
复制
@Slf4j
@SpringBootApplication
public class Application implements ApplicationRunner {
    @Autowired
    private JdbcTemplate jdbcTemplate;

    public static void main(String[] args) {
        SpringApplication.run(Application.class);
    }

    @Override
    public 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 , 取值为

代码语言:javascript
复制
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

本文作为数据初始化第二篇,推荐与前文对比阅读,收获更多的知识点 【DB系列】 数据库初始化-datasource配置方式

III. 不能错过的源码和相关知识点

0. 项目

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-12-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • I. 项目搭建
    • 1. 依赖
      • 2. 配置
      • II. 示例
        • 1. 验证demo
          • 2. 初始化数据
            • 3. 小结
            • III. 不能错过的源码和相关知识点
              • 0. 项目
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档