有没有办法阻止空值被持久化,同时允许其他人通过?

Fre*_*eit 5 java annotations jpa

我有一个现有的JPA(EclipseLink)项目,其中所需的行为是,如果在实体的字段中给出空值,则不应该保留该空值.

用例是我们可以从外部源获得对这些实体的多个部分更新.这些来源可能会给我们一个空值,这并不意味着"使这个领域无效",这意味着"我没有这个价值".

是否有注释,模式或其他工具可用于在setter中自动执行null检查或告诉JPA不保持空值????

我可以在每个实体中查看每个setter并添加,if(val != null) { //set the value } 但这是乏味和重复的.

例如,我们有:


@Entity
@Table(name = "my_table")
public class MyObject {
 @Column
 private String myColumn;

 public String getMyColumn() {
  return this.myColumn;
 }

 public void setMyColumn(String val) {
  this.myColumn = val;
 }
}
Run Code Online (Sandbox Code Playgroud)

我想有一些自动帮助的东西:


@Entity
@Table(name = "my_table")
public class MyObject {
 @Column
 @DontPersistIfNull
 private String myColumn;

 public String getMyColumn() {
  return this.myColumn;
 }

 public void setMyColumn(String val) {
  this.myColumn = val;
 }
}
Run Code Online (Sandbox Code Playgroud)

或这个:


@Entity
@Table(name = "my_table")
public class MyObject {
 @Column
 private String myColumn;

 public String getMyColumn() {
  return this.myColumn;
 }

 public void setMyColumn(String val) {
  //AUTOGENERATED NULL CHECK
  if(val != null) {
   this.myColumn = val;
  }
 }
}
Run Code Online (Sandbox Code Playgroud)

Boz*_*zho 2

Hibernate 验证器(以及 的任何实现javax.validation)具有@NotNull注释,如果注释属性为 null,则将不允许实体被持久化。我不确定是否hibernate-validator可以与 EclipseLink 一起使用,但也应该有一个javax.validationEclipseLink 的实现。

但是,如果您想阻止设置空值 - 那么,请修改设置值的图层,而不是实体本身。