8

This works fine:

 public Predicate toPredicate(Root<Campaign> root,
    CriteriaQuery<?> query, CriteriaBuilder cb) {
    return root.get("campState").get("statusId").in(campStatus);
}

but I change to :

 return  root.get(Campaign_.campState).get(CampState_.campId).in(campStatus).

And it throws exception:

edit for: NullPointerException at org.hibernate.ejb.criteria.path.AbstractPathImpl.get

  @StaticMetamodel(Campaign.class)
  public class Campaign_ {
  public static volatile SingularAttribute<Campaign, CampState> campState;
  public static volatile SingularAttribute<Campaign, Long> campId;
  }

  @StaticMetamodel(CampState.class)
  public class CampState_ {
  public static volatile SingularAttribute<CampState, String> statusId;
  }

  Campaign.class
  @ManyToOne(cascade = {CascadeType.REFRESH, CascadeType.MERGE})
  @JoinColumn(name = "camp_status")
  public CampState getCampState() {
    return campState;
  }

  public void setCampState(CampState campState) {
    this.campState = campState;
  }
Brian Tompsett - 汤莱恩
  • 5,753
  • 72
  • 57
  • 129
samung88
  • 121
  • 1
  • 5

2 Answers2

2

check this answer.

seems like metamodel and class should be at the same package

Community
  • 1
  • 1
oak
  • 2,898
  • 2
  • 32
  • 65
0

Given two queries operate to different attributes. Second query cannot be compiled, because CampState_ does not have attribute campId (Campaign_ does have such a attribute.

Query that is equivalent to first one with static metamodel is:

root.get(Campaign_.campState).get(CampState_.statusId).in(campStatus).
Mikko Maunu
  • 41,366
  • 10
  • 132
  • 135