Spring Data Jpa 自動生成表結(jié)構(gòu)的方法示例
想在部署的時候隨應(yīng)用的啟動而初始化數(shù)據(jù)腳本,這不就是Spring Data Jpa中的自動生成表結(jié)構(gòu),聽起來特別簡單,不就是配置Hibernate的ddl-auto嘛,有什么好說的,是個人都知道。當(dāng)初我也是這樣認(rèn)為,實際操作了一把,雖然表是創(chuàng)建成功了,但是字段注釋,字符集以及數(shù)據(jù)庫引擎都不對,沒想到在這些細(xì)節(jié)上翻車了。
畢竟開翻的車還要自己扶起來,于是在這記錄一下。
注:本文中使用的Spring Data Jpa版本為2.1.4.RELEASE
以MySQL為例,我這邊舉個例子:
import com.fasterxml.jackson.annotation.*;
import org.hibernate.annotations.*;
import org.springframework.data.annotation.*;
import javax.persistence.*;
import javax.persistence.Entity;
import javax.persistence.Id;
import java.math.BigDecimal;
@Entity
@javax.persistence.Table(name = "basic_city")
@org.hibernate.annotations.Table(appliesTo = "basic_city", comment = "城市基本信息")
public class CityDO {
@Id
@GenericGenerator(name = "idGenerator", strategy = "uuid")
@GeneratedValue(generator = "idGenerator")
@Column(name = "CITY_ID", length = 32)
private String cityId;
@Column(name = "CITY_NAME_CN", columnDefinition = "VARCHAR(255) NOT NULL COMMENT '名稱(中文)'")
private String cityNameCN;
@Column(name = "CITY_NAME_EN", columnDefinition = "VARCHAR(255) NOT NULL COMMENT '名稱(英文)'")
private String cityNameEN;
@Column(name = "LONGITUDE", precision = 10, scale = 7)
private BigDecimal longitude;
@Column(name = "LATITUDE", precision = 10, scale = 7)
private BigDecimal latitude;
@Column(name = "ELEVATION", precision = 5)
private Integer elevation;
@Column(name = "CITY_DESCRIPTION", length = 500)
private String cityDescription;
// 構(gòu)造方法及get/set方法省略
}
- @javax.persistence.Table 修改默認(rèn)ORM規(guī)則,屬性name設(shè)置表名;
- @org.hibernate.annotations.Table 建表時的描述, 屬性comment修改表描述;
- @Id 主鍵
- @GenericGenerator 設(shè)置主鍵策略,這里使用了Hibernate的UUID來生成主鍵;
- @GeneratedValue 設(shè)置主鍵值,屬性generator關(guān)聯(lián)主鍵策略的name;
- @Column 修改默認(rèn)ORM規(guī)則;
- name設(shè)置表中字段名稱,表字段和實體類屬性相同,則該屬性可不寫;
- unique設(shè)置該字段在表中是否唯一,默認(rèn)false;
- nullable是否可為空,默認(rèn)true;
- insertable表示insert操作時該字段是否響應(yīng)寫入,默認(rèn)為true;
- updatable表示update操作時該字段是否響應(yīng)修改,默認(rèn)為true;
- columnDefinition是自定義字段,可以用這個屬性來設(shè)置字段的注釋;
- table表示當(dāng)映射多個表時,指定表的表中的字段,默認(rèn)值為主表的表名;
- length是長度,僅對varchar類型的字段生效,默認(rèn)長度為255;
- precision表示一共多少位;
- scale表示小數(shù)部分占precision總位數(shù)的多少位,例子中兩者共同使用來確保經(jīng)緯度的精度;
接下來需要設(shè)置數(shù)據(jù)引擎和字符集,網(wǎng)上大把的繼承MySQL5InnoDBDialect,但是這個類已經(jīng)過期了,我們用MySQL5Dialect來代替:
package com.jason.config;
import org.hibernate.dialect.MySQL5Dialect;
import org.springframework.stereotype.Component;
@Component
public class MySQL5TableType extends MySQL5Dialect {
@Override
public String getTableTypeString() {
return "ENGINE=InnoDB DEFAULT CHARSET=utf8";
}
}
然后在Spring Boot的配置文件中應(yīng)用上面定義的MySQL5TableType ,使用spring.jpa.properties.hibernate.dialect配置:
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/techno?useUnicode=true&characterEncoding=utf8
username: root
password: root
jpa:
show-sql: true
hibernate:
ddl-auto: update
database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
properties:
hibernate:
dialect: com.jason.config.MySQL5TableType
到此,Sprign Data Jpa生成表就完成了,應(yīng)用就可以通過ApplicaitonRunner或者CommandLineRunner接口一鍵部署應(yīng)用,省去初始化SQL等不必要的操作了,這兩個接口的簡單使用可以參考我的另外一篇文章。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java中十六進制和十進制之間互相轉(zhuǎn)換代碼示例
這篇文章主要給大家介紹了關(guān)于Java中十六進制和十進制之間互相轉(zhuǎn)換的相關(guān)資料,我們項目過程中總是要用到十進制與十六進制相互轉(zhuǎn)換的方法,需要的朋友可以參考下2023-07-07
SpringBoot封裝自己的Starter的實現(xiàn)方法
這篇文章主要介紹了SpringBoot封裝自己的Starter的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04
Spring Boot 通過注解實現(xiàn)數(shù)據(jù)校驗的方法
這篇文章主要介紹了Spring Boot 通過注解實現(xiàn)數(shù)據(jù)校驗的方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
SpringCloud2020整合Nacos-Bootstrap配置不生效的解決
這篇文章主要介紹了SpringCloud2020整合Nacos-Bootstrap配置不生效的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Struts2學(xué)習(xí)筆記(3)-DMI動態(tài)調(diào)用方式
本文主要介紹Struts2的DMI動態(tài)調(diào)用的兩種方式,簡單實用,希望能給大家做一個參考。2016-06-06
springcloud gateway設(shè)置context-path的操作
這篇文章主要介紹了springcloud gateway設(shè)置context-path的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07

