SpringBoot+jpa配置如何根据实体类自动创建表

网友投稿 583 2022-11-21

SpringBoot+jpa配置如何根据实体类自动创建表

目录jpa配置根据实体类自动创建表1.配置文件application.properties2.pom.xml引入包3.编写实体类4.运行项目5.针对项目启动以后数据库并未生成数据库表问题jpa根据Entry自动生成表1.加入依赖2.配置 application.yml3. 创建Entity

jpa配置根据实体类自动创建表

1.配置文件application.properties

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

2.pom.xml引入包

org.springframework.boot

spring-boot-starter-data-jpa

org.springframework.boot

spring-boot-starter-data-jpa

mysql

mysql-connector-java

3.编写实体类

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方法

}

4.运行项目

启动即可生成

5.针对项目启动以后数据库并未生成数据库表问题

包导的不对: import javax.persistence.*;

配置文件不对: spring.jpa.hibernate.ddl-auto=update

注解写的不对:不要忘记@Entity

还可能有一种原因:

Sprint的入口文件在子目录里了,应该比其他诸如service、dao、controller、entity高一级。

例如:service文件所在为com.demo.metaService,那么入口文件xxxApplication.java应该在com.demo下

jpa根据Entry自动生成表

1.加入依赖

org.springframework.boot

spring-boot-starter-data-jpa

若有依赖 spring-data-jpa 则删掉,否则会出现找不到 bootstrap 之类的错误

2.配置 application.yml

增加Jpa 自动生成表的配置

spring:

jpa: ##配置自动建表:updata:没有表新建,有表更新操作,控制台显示建表语句

hibernate:

ddl-auto: update

show-sql: true

3. 创建Entity

个人建议创建一个基础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;

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:EMBEST ATMEL SAM9G45全功能评估开发解决方案
下一篇:平台工具+数仓构建数据产品(二)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~