- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下有效方法:
public List<Course> filterOn(String course, String university, List<String> providers, String sortOn, int page) {
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
List<Predicate> predicates = new ArrayList<Predicate>();
CriteriaQuery criteriaQuery = criteriaBuilder.createQuery();
Root r = criteriaQuery.from(Course.class);
criteriaQuery.select(r);
predicates.add(criteriaBuilder.like(r.get("name"), "%" + course + "%"));
predicates.add(criteriaBuilder.like(r.get("university").get("name"), "%" + university + "%"));
predicates.add(criteriaBuilder.or(criteriaBuilder.like(r.get("type"), providers.get(0)),
criteriaBuilder.like(r.get("type"), providers.get(1)),
criteriaBuilder.like(r.get("type"), providers.get(2)),
criteriaBuilder.like(r.get("type"), providers.get(3))));
if (predicates != null && !predicates.isEmpty()) {
criteriaQuery.where(criteriaBuilder.and(predicates.toArray(new Predicate[0])));
}
if (sortOn.equals("ranks")) {
criteriaQuery.orderBy(criteriaBuilder.asc(r.get("averageScoreLastSemester")));
} else if (sortOn.equals("name")) {
criteriaQuery.orderBy(criteriaBuilder.desc(r.get("name")));
}
final TypedQuery query = entityManager.createQuery(criteriaQuery);
query.setFirstResult(page * COURSES_PER_PAGE);
query.setMaxResults(COURSES_PER_PAGE);
return query.getResultList();
}
问题是它只对当前页面进行排序。我希望它根据数据库中所有匹配的记录进行排序,然后返回当前页面。我怎样才能做到这一点?
来自日志:
select
course0_.id as id1_14_,
course0_.created as created2_14_,
course0_.updated as updated3_14_,
course0_.averageScoreLastSemester as averageS4_14_,
course0_.avgAverageArray as avgAvera5_14_,
course0_.avgStructureArray as avgStruc6_14_,
course0_.avgTeachersArray as avgTeach7_14_,
course0_.avgWorkloadArray as avgWorkl8_14_,
course0_.code as code9_14_,
course0_.courseLink as courseL10_14_,
course0_.credits as credits11_14_,
course0_.level as level12_14_,
course0_.name as name13_14_,
course0_.numberOfAssignments as numberO14_14_,
course0_.numberOfExams as numberO15_14_,
course0_.numberOfProjects as numberO16_14_,
course0_.pace as pace17_14_,
course0_.rankCountArray as rankCou18_14_,
course0_.requirementsLink as require19_14_,
course0_.semester as semeste20_14_,
course0_.teacherName as teacher21_14_,
course0_.type as type22_14_,
course0_.university_id as univers23_14_
from
courses course0_ cross
join
universities university1_
where
course0_.university_id=university1_.id
and (
course0_.name like ?
)
and (
university1_.name like ?
)
and (
course0_.type like ?
or course0_.type like ?
or course0_.type like ?
or course0_.type like ?
)
order by
course0_.name desc limit ?
Hibernate:
select
course0_.id as id1_14_,
course0_.created as created2_14_,
course0_.updated as updated3_14_,
course0_.averageScoreLastSemester as averageS4_14_,
course0_.avgAverageArray as avgAvera5_14_,
course0_.avgStructureArray as avgStruc6_14_,
course0_.avgTeachersArray as avgTeach7_14_,
course0_.avgWorkloadArray as avgWorkl8_14_,
course0_.code as code9_14_,
course0_.courseLink as courseL10_14_,
course0_.credits as credits11_14_,
course0_.level as level12_14_,
course0_.name as name13_14_,
course0_.numberOfAssignments as numberO14_14_,
course0_.numberOfExams as numberO15_14_,
course0_.numberOfProjects as numberO16_14_,
course0_.pace as pace17_14_,
course0_.rankCountArray as rankCou18_14_,
course0_.requirementsLink as require19_14_,
course0_.semester as semeste20_14_,
course0_.teacherName as teacher21_14_,
course0_.type as type22_14_,
course0_.university_id as univers23_14_
from
courses course0_ cross
join
universities university1_
where
course0_.university_id=university1_.id
and (
course0_.name like ?
)
and (
university1_.name like ?
)
and (
course0_.type like ?
or course0_.type like ?
or course0_.type like ?
or course0_.type like ?
)
order by
course0_.name desc limit ?
我想最后一行很重要,我在某处读到它应该首先对所有记录进行排序,然后限制它们。那么这似乎是正确的?
我使用hibernate方言org.hibernate.dialect.MySQL5Dialect
,数据源使用com.mysql.jdbc.Driver
。
谢谢。
最佳答案
也许 View 技术有问题?您是否运行了 Sysout resultList 来确认排序顺序问题来自 JPA?当你切换到第二页时,过滤器还在吗?
关于mysql - 分页 Hibernate JPA : orderBy + setFirstResult + setMaxResult,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27880322/
我有一个类,它返回查询中的所有实体,受最大值和最小值限制: @SuppressWarnings("unchecked") public static List getAll(Class klass,
我是 hibernate 新手。我对标准的 setFirstResult 方法感到困惑。从文档看来,hibernate 从给定的数字返回行。 由于 SQL 查询不保证没有 order by 子句的行的
我正在使用 nHibernate 并尝试实现一些分页。如果我运行这段代码 IList list = session.CreateQuery("FROM Author").List(); 它返回 8 条
我的应用程序中有分页问题。我想使用 setFirstResult 和 setMaxResults 方法,但它给了我错误的输出: (我的数据库:SQLite) 例子: Session sessi
什么会导致 CriteriaQuery orderBy 方法停止工作? 实现如下: OpenJPAEntityManager kem = OpenJPAPersistence.cast(ent
JPA setFirstResult() 和 setMaxResults() 方法是否进行真正的分页?我的意思是从数据库的角度来看?还是不? 例如,如果查询返回 1000000 行,并且我使用这些方法
什么会导致 CriteriaQuery orderBy 方法停止工作? 实现如下: OpenJPAEntityManager kem = OpenJPAPersistence.cast(ent
我的数据库中有 10000 条记录,我想第一次获取 100 条记录,第二次获取 100 条记录,依此类推。我正在使用 setFirstResult() 和 maxResult()。我正在维护一个计数器
我使用 ORM 框架已有一段时间了,但我对 Hibernate 还是比较陌生。 假设您有一个查询(它是一个查询还是一个条件,无关紧要)检索了一个很好的结果集并且您想要对其进行分页。您更愿意使用 set
我有以下有效方法: public List filterOn(String course, String university, List providers, String sortOn, int
我正在开发一个使用 Hibernate 作为 ORM 框架的 Java EE 项目。为了对查询结果进行分页,我使用了 .setFirstResult 和 .setMaxResult 方法(Criter
当我使用 SetFirstResult 和 SetMaxResult 时,如果查询已连接,则结果具有重复结果而不是唯一结果。 然后我将所有类型的 Distinct 助手用于标准 api。但它不会过滤整
我正在尝试使用 setFirstResult() 和 setMaxResults() 对 Hibernate 进行分页,但是当将第一个结果设置为 0 时我没有得到预期的结果. 执行以下操作时: Que
有没有办法从已经构建的 DetachedCriteria 中删除/撤消 .SetMaxResults()/.SetFirstResults()? 不改变原来的DetachedCriteria就可以做到
这个查询: $this->getEntityManager() ->createQuery("SELECT k FROM FooBarBundle:Kode k WHERE k.kod
我是一名优秀的程序员,十分优秀!