JPA注解实体类,给表添加创建时间,更新时间,id的生成以及创建唯一约束

时间:2021-09-25 17:01:35

首先创建一个BaseModel,自动生成创建时间和更新时间

@SuppressWarnings("serial")
@MappedSuperclass
public class BaseModel implements Serializable{ @Temporal(TemporalType.TIMESTAMP)
@Column(insertable=false, updatable=false)
@CreationTimestamp
protected Date createTime; @JsonIgnore
@Temporal(TemporalType.TIMESTAMP)
@Column(insertable=false)
@UpdateTimestamp
protected Date lastUpdateTime; public Date getCreateTime() {
return createTime;
} public void setCreateTime(Date createTime) {
this.createTime = createTime;
} public Date getLastUpdateTime() {
return lastUpdateTime;
} public void setLastUpdateTime(Date lastUpdateTime) {
this.lastUpdateTime = lastUpdateTime;
} }

然后创建一个RandomIdModel,利用org.hibernate.id.UUIDHexGenerator生成的uuid作为主键

@SuppressWarnings("serial")
@MappedSuperclass
public class RandomIdModel extends BaseModel { @Id
@Column(length=32)
@GeneratedValue(generator="UUIDHexGenerator")
@GenericGenerator(name="UUIDHexGenerator", strategy="uuid")
protected String id; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} }

然后就可以创建其他的具体实体类继承上面的model了,这样就保证了所有的表都会有创建时间和更新时间了

@SuppressWarnings("serial")
@Entity
@Table(name="tb_user",
indexes={ @Index(name=User.UK_NAME, unique=true, columnList="name"),
@Index(name=User.UK_PHONE, unique=true, columnList="phone")})
public class User extends RandomIdModel{ public static final String UK_NAME = "uk_name";
public static final String UK_PHONE = "uk_phone"; @Column(length=24)
private String name; @Column(length=32)
private String password; @Temporal(TemporalType.TIMESTAMP)
private Date birth; @Enumerated(EnumType.STRING)
@Column(length=8)
private Sex sex; @Column(length=64)
private String email; @Column(length=11)
private String phone; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} public Date getBirth() {
return birth;
}
public void setBirth(Date birth) {
this.birth = birth;
} public Sex getSex() {
return sex;
}
public void setSex(Sex sex) {
this.sex = sex;
} public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
} public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
}

创建唯一索引时,自定义索引名,有利于后续业务判断。

当插入数据不唯一时,可根据抛出的异常,明确知道是哪个字段违反约束导致的

if(e.getCause() instanceof ConstraintViolationException){
String constraintName = ((ConstraintViolationException)e.getCause()).getConstraintName();
if(constraintName.equals(User.UK_NAME)){
return Resp.error(Resp.ErrorCode.USER_NAME_EXITS, null);
}
if(constraintName.equals(User.UK_PHONE)){
return Resp.error(Resp.ErrorCode.USER_PHONE_EXITS, null);
}
}