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

时间:2010-01-18 19:46:59

标签: java jpa annotations

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

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

是否有注释,模式或其他工具可用于在setter中自动执行空检查或告诉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;
 }
}

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


@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;
 }
}

或者这个:


@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;
  }
 }
}

2 个答案:

答案 0 :(得分:2)

不确定这是否是您正在寻找的答案,但是您检查了Null Object Design Pattern

答案 1 :(得分:2)

Hibernate validator(以及javax.validation的任何实现)都有@NotNull注释,如果注释属性为null,则会禁止实体持久化。我不确定hibernate-validator是否适用于EclipseLink,但是对于EclipseLink也应该有javax.validation的实现。

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