对此有很多疑问,但我找不到具体的答案。
我是 Hibernate 新手,正在尝试实现分页。
假设我有两个实体:Parent 和 Child,定义如下:
@Entity
@Table(name="Parents")
public class Parent{
@Id
@Column(name="id", length=255)
private String id;
@Column(name="name", length=255)
protected String name;
@OneToMany
@JoinTable(name="parents_children", joinColumns = @JoinColumn( name="parent_id"), inverseJoinColumns = @JoinColumn( name="child_id"))
@LazyCollection(LazyCollectionOption.FALSE)
protected List<Child> children;
}
@Entity
@Table(name="children")
public class Child {
@Id
@Column(name="id", length=255)
protected String id;
@Column(name="name", length=255)
protected String name;
}
每个属性还根据需要具有 getter 和 setter。
我想要得到第一页 of Parents 按名称排序, where 每页有 10 个结果.
所以我从:
Session session = HibernateUtil.getSessionFactory().openSession();
Criteria c = session.createCriteria(Parent.class, "p");
c.createAlias("q.children", "ch");
c.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY);
c.addOrder(Order.desc("name"));
c.setMaxResults(10);
c.setFirstResult(0);
List<Parent> result = c.list();
session.close();
此代码无法按预期工作,因为 setMaxResults 是在联接表上执行的,而不是在父列表上执行的(正如我希望的那样)。
我的问题是应该使用什么查询来在“父级”列表上而不是在连接表上进行分页?