【发布时间】:2019-09-02 15:38:52
【问题描述】:
我有一个简单的CrudRepository 接受可排序的:
class PersonReposiroty extends CrudRepository<Person, Long> {
findAll(Pageable page);
}
我想通过两个字段的sum对其进行排序:
dao.findAll(PageRequest.of(page, size, Sort.by("price1, price2"));
问题:首先按price1 排序,然后按price2。以前怎么求和?
【问题讨论】:
-
我认为到那时你必须写一个明确的查询。
-
由于这只支持按映射的数据库列排序,因此您需要使用计算值创建一个视图,然后使用
@SecondaryTable将其映射为实体中的字段以从中提取值视图。 -
我必须将视图创建为模型 bean 还是数据库表?我更喜欢编程解决方案,而不必接触数据库...
-
没有模型 bean。使用
@SecondaryTable将数据库视图列映射到退出实体。强大的选项,您可以在数据库中对任何其他持久属性进行排序、过滤等。否则,您需要实现自己的查询逻辑。例如stackoverflow.com/questions/53176186/…
标签: java spring jpa spring-data-jpa spring-data