简体   繁体   English

Hibernate Fetch不再是Join的子类型

[英]Hibernate Fetch is not longer sub-type of Join

I'm using Hibernate 5.2.10 with dynamic criteria and find out that Fetch is not longer assignable to Join. 我正在使用带有动态条件的Hibernate 5.2.10,并发现Fetch不再可以分配给Join。

In the next example, I need to fetch group data in the same query, but I also need to use the group's field for sorting or restriction. 在下一个示例中,我需要在同一查询中获取组数据,但我还需要使用组的字段进行排序或限制。

CriteriaBuilder cb = session.getCriteriaBuilder();
CriteriaQuery<GroupAssignment> query = cb.createQuery(GroupAssignment.class);

Root<GroupAssignment> root = query.from(GroupAssignment.class);
SingularAttributeJoin<GroupAssignment, Group> groupFetch = (SingularAttributeJoin<GroupAssignment, Group>) root.fetch(GroupAssignment_.group, JoinType.LEFT);
query.orderBy(cb.asc(groupFetch.get(Group_.title)));

I have manually cast Fetch to the SingularAttributeJoin and after that, I can use get method for the ordering purpose, but I'm looking for the right way how I can do that without casting manually . 我已经手动将Fetch转换为SingularAttributeJoin,之后,我可以使用get方法进行排序,但我正在寻找正确的方法, 如果不手动编译我怎么做。

GroupAssignment class: GroupAssignment类:

@Entity()
@Table(name = "group_assignment")
public class GroupAssignment {
  @Id
  @Column(name = "group_assignment_id")
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Integer id;

  @ManyToOne
  @JoinColumn(name = "group_id", nullable = false)
  private Group group;

  //other fields, getters and setters
}

GroupAssignment_ class: GroupAssignment_类:

@Generated(value = "org.hibernate.jpamodelgen.JPAMetaModelEntityProcessor")
@StaticMetamodel(GroupAssignment.class)
public abstract class GroupAssignment_ {
  public static volatile SingularAttribute<GroupAssignment, Integer> id;
  public static volatile SingularAttribute<GroupAssignment, Group> group;
}

Group class: 小组课程:

@Entity()
@Table(name = "navigation_group")
public class Group {
  @Id
  @Column(name = "group_id")
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Integer id;

  @Column(name = "title")
  private String title;

  //other fields, getters and setters
}

Group_ class: Group_类:

@Generated(value = "org.hibernate.jpamodelgen.JPAMetaModelEntityProcessor")
@StaticMetamodel(Group.class)
public abstract class Group_ {
  public static volatile SingularAttribute<Group, Integer> id;
  public static volatile SingularAttribute<Group, String> title;
}

我认为javax.persistence.criteria.FetchParent可以解决您的问题:

FetchParent<GroupAssignment, Group> groupFetch = root.fetch(GroupAssignment_.group, JoinType.LEFT);

It appears that correct way would be next: 看来正确的方法是下一个:

query.orderBy(cb.asc(root.get(GroupAssignment_.group).get(Group_.title)));

So using multiple call to .get method you can go as deep as needed. 因此,使用多次调用.get方法,您可以根据需要尽可能深入。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM