您好,登錄后才能下訂單哦!
這篇文章主要介紹“SpringBoot+jpa配置怎么根據實體類自動創建表”,在日常操作中,相信很多人在SpringBoot+jpa配置怎么根據實體類自動創建表問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”SpringBoot+jpa配置怎么根據實體類自動創建表”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
spring.datasource.url=jdbc:mysql://localhost:3306/bootTable?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.jpa.database=mysql spring.jpa.show-sql=true spring.jpa.hibernate.ddl-auto=update spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency>
import javax.persistence.*; import java.io.Serializable; import java.util.Objects; @Entity //聲明實體類 public class User implements Serializable { @Id //聲明了實體唯一標識對應的屬性 @GeneratedValue //自增 private Integer id; @Column(nullable = false, unique = true, length = 32) //長度32,唯一索引,nullable表示true可以為空,false不可以 //用來聲明實體屬性的表字段的定義 private String userName; private String passWord; private String email; private String nickName; private String regTime; @Transient //不映射成列的字段 private String desc; //省略get和set方法 }
啟動即可生成
包導的不對: import javax.persistence.*;
配置文件不對: spring.jpa.hibernate.ddl-auto=update
注解寫的不對:不要忘記@Entity
…
還可能有一種原因:
Sprint的入口文件在子目錄里了,應該比其他諸如service、dao、controller、entity高一級。
例如:service文件所在為com.demo.metaService,那么入口文件xxxApplication.java應該在com.demo下
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
若有依賴 spring-data-jpa 則刪掉,否則會出現找不到 bootstrap 之類的錯誤
<!-- <dependency>--> <!-- <groupId>org.springframework.data</groupId>--> <!-- <artifactId>spring-data-jpa</artifactId>--> <!-- <version>2.1.4.RELEASE</version>--> <!-- </dependency>-->
增加Jpa 自動生成表的配置
spring: jpa: ##配置自動建表:updata:沒有表新建,有表更新操作,控制臺顯示建表語句 hibernate: ddl-auto: update show-sql: true
個人建議創建一個基礎Entity,用于表中常用字段創建配合 mybatisplus,jackson,SnowFlake,lombok 等庫,自行導入相關注解請自行了解
BaseEntry.java
@Data//省略setget方法 @MappedSuperclass //標注父類 @EntityListeners(AuditingEntityListener.class) //jpa數據監聽 @JsonIgnoreProperties(value={"hibernateLazyInitializer","handler","fieldHandler"}) //忽略解析的字段 public abstract class BaseEntry implements Serializable{ private static final long serialVersionUID = 1L; @Id @TableId @ApiModelProperty(value = "唯一標識") private String id = String.valueOf(SnowFlakeUtil.getFlowIdInstance().nextId()); @ApiModelProperty(value = "創建者") @CreatedBy private String createBy; @CreatedDate @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @ApiModelProperty(value = "創建時間") private Date createTime; @ApiModelProperty(value = "更新者") @LastModifiedBy private String updateBy; @LastModifiedDate @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @ApiModelProperty(value = "更新時間") private Date updateTime; @ApiModelProperty(value = "刪除標志 默認0") @TableLogic private Integer delFlag = CommonConstant.STATUS_NORMAL; }
業務Entry ,僅做參考
/** * tb_bussiness_up_record實體類 * * @author * */ @Data @Entity @Table(name = "tb_bussiness_up_record") @TableName("tb_bussiness_up_record") public class TbBussinessUpRecord extends BaseEntry { private static final long serialVersionUID = 1L; @ApiModelProperty(value = "經銷商") private String bussinessId; @ApiModelProperty(value = "審核時間") @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private String auditTime; }
到此,關于“SpringBoot+jpa配置怎么根據實體類自動創建表”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。