加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – Spring Data JPA – JpaRepository中的自定义排序

发布时间:2020-12-15 02:10:51 所属栏目:Java 来源:网络整理
导读:我使用 Spring Data JPA和Spring Data REST,并为我的Thing实体创建了一个JpaRepository. @Repositorypublic interface ThingRepository extends JpaRepositoryThing,Long { @RestResource(path = "findByName",rel = "findByName") Page findByName(@Param("
我使用 Spring Data JPA和Spring Data REST,并为我的Thing实体创建了一个JpaRepository.

@Repository
public interface ThingRepository extends JpaRepository<Thing,Long> {

    @RestResource(path = "findByName",rel = "findByName")
    Page findByName(@Param("name") String name,Pageable page);

}

我想申请排序.我想根据自定义评级算法对Thing List进行排序.

List<Thing> sortByRating(List<Thing> things){

    // custom logic

    return things;
};

我想尽可能使用自定义函数来排序结果.在Spring JPA中,这种事情的最佳方法是什么?如何让我的存储库使用我的函数来对结果集进行排序?

解决方法

Spring Data提供基本排序,如 here所示.您也可以使用@Query注释查询并使用order by,但我相信您需要的是更复杂的排序逻辑.

如果您使用的是Java 8,您可以使用它的功能对列表进行排序,this文章显示了很好的例子,它需要更多的工作,但看起来就像您所追求的那样.请注意,要从流转换为列表,您必须包含.collect(Collectors.toList());在流的最后.

示例(摘自文章):

employees.stream().sorted((Employee e1,Employee e2) -> e1.getHireDate()
                        .compareTo(e2.getHireDate())).collect(Collectors.toList());

编辑:我没注意到你正在使用分页.我有一个类似的问题,我必须在返回Page对象之前对页面内容做一些事情,所以我最终创建了PageImpl< T>的扩展了.类:

public class PageImplBean<T> extends PageImpl<T> {

    private static final long serialVersionUID = 1L;
    private int number;
    private int size;
    private int totalPages;
    private int numberOfElements;
    private long totalElements;
    private boolean previousPage;
    private boolean first;
    private boolean nextPage;
    private boolean last;
    private List<T> content;
    @JsonIgnore
    private Sort sort;

    public PageImplBean() {
        super(new ArrayList<T>());
    }

    public PageImplBean(Page pagina){
        super(new ArrayList<T>());
        this.number = pagina.getNumber();
        this.size = pagina.getSize();
        this.totalPages = pagina.getTotalPages();
        this.numberOfElements = pagina.getNumberOfElements();
        this.totalElements = pagina.getTotalElements();
        this.previousPage = pagina.hasPrevious();
        this.first = pagina.isFirst();
        this.nextPage = pagina.hasNext();
        this.last = pagina.isLast();
    }

    public int getNumber() {
        return number;
    }

    public void setNumber(int number) {
        this.number = number;
    }

    public int getSize() {
        return size;
    }

    public void setSize(int size) {
        this.size = size;
    }

    public int getTotalPages() {
        return totalPages;
    }

    public void setTotalPages(int totalPages) {
        this.totalPages = totalPages;
    }

    public int getNumberOfElements() {
        return numberOfElements;
    }

    public void setNumberOfElements(int numberOfElements) {
        this.numberOfElements = numberOfElements;
    }

    public long getTotalElements() {
        return totalElements;
    }

    public void setTotalElements(long totalElements) {
        this.totalElements = totalElements;
    }

    public boolean isPreviousPage() {
        return previousPage;
    }

    public void setPreviousPage(boolean previousPage) {
        this.previousPage = previousPage;
    }

    public boolean isFirst() {
        return first;
    }

    public void setFirst(boolean first) {
        this.first = first;
    }

    public boolean isNextPage() {
        return nextPage;
    }

    public void setNextPage(boolean nextPage) {
        this.nextPage = nextPage;
    }

    public boolean isLast() {
        return last;
    }

    public void setLast(boolean last) {
        this.last = last;
    }

    public List<T> getContent() {
        return content;
    }

    public void setContent(List<T> content) {
        this.content = content;
    }

    public Sort getSort() {
        return sort;
    }

    public void setSort(Sort sort) {
        this.sort = sort;
    }

    public PageImpl<T> pageImpl() {
        return new PageImpl<T>(getContent(),new PageRequest(getNumber(),getSize(),getSort()),getTotalElements());
    }
}

在你的情况下,重要的是setContent方法,它不存在于基类中.您可以将它与您的排序方法一起使用:

PageImplBean<Thing> page = //call your rest repository
List<Thing> pageContent = page.getContent();
page.setContent(sortByRating(pageContent));

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读