IntelliJ IDEA 2017版 spring-boot2.0.2 搭建 JPA springboot DataSource JPA环境搭建,JPA注解@ManyToOne使用详情;JPA外键设置

一、数据库原型

IntelliJ IDEA 2017版 spring-boot2.0.2 搭建 JPA springboot DataSource JPA环境搭建,JPA注解@ManyToOne使用详情;JPA外键设置

IntelliJ IDEA 2017版 spring-boot2.0.2 搭建 JPA springboot DataSource JPA环境搭建,JPA注解@ManyToOne使用详情;JPA外键设置

数据库模型如图所示,而现在需要根据数据库模型,建立对应的实体类,这在项目重构老数据库,采用新的框架重构上应该是比较常见的。

数据库脚本如下:

 CREATE TABLE `bomsub` (
`subId` varchar(40) NOT NULL COMMENT '子类型ID',
`mainId` varchar(40) NOT NULL COMMENT '主类型ID',
`subName` varchar(40) NOT NULL COMMENT '子类型名称',
`engName` varchar(255) NOT NULL,
`deleted` int(1) NOT NULL DEFAULT '' COMMENT '当前是否删除',
PRIMARY KEY (`subId`),
KEY `FK_Reference_47` (`mainId`),
CONSTRAINT `FK_Reference_47` FOREIGN KEY (`mainId`) REFERENCES `bommain` (`mainId`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='Bom表的小类';

实体类构成:

 @Entity
@Table(name = "bomsub")
public class BomSub extends SuperEntity { /**
* 子类型ID
*/
@Id
@GenericGenerator(strategy = "uuid", name = "subId")
@GeneratedValue(generator = "subId")
@Column(length = 40)
public String subId; /**
* 主类型ID
*/
@ManyToOne(cascade = {CascadeType.ALL})
@JoinColumn(name = "mainId", foreignKey = @ForeignKey(name = "FK_Reference_47"), columnDefinition = "varchar(40) NOT NULL COMMENT '主类型ID'")
public BomMain bomMain; /**
* 子类型名称
*/
@Column(nullable = false, length = 40)
public String subName; /**
* 英文名称
*/
@Column(nullable = false)
public String engName; /**
* 所有字段的是否存在
*/
@Column(nullable = false, columnDefinition = "int(1) default 1 COMMENT '当前是否删除'")
public Integer deleted; }

主要部分:

/**
* 主类型ID
*/
@ManyToOne(cascade = {CascadeType.ALL})
@JoinColumn(name = "mainId", foreignKey = @ForeignKey(name = "FK_Reference_47"), columnDefinition = "varchar(40) NOT NULL COMMENT '主类型ID'")
public BomMain bomMain;

@ManyToOne表明表的关系是多对一,就是子表bomsub的mainId,是一个,但是对应着多个bomMain的Id

@JoinColumn 表明两个表是如何关联的,关联需要的条件

内部属性  name : 关联两个表外键的名称

foreignKey :外键的设置,这里对其名称进行设置,就会将索引的名称设置为这里名字的设置

columnDefinition :DDL拼接,这里指的是这个属性的SQL语句的设置

当这个表生成的时候就会把剩下的部分在JPA模式下自动生成设置的SQL语句。

上一篇:oracle No more data to read from socket之ora-07445排查解决


下一篇:jdbc配置Spring