gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-10-31 08:04:29 24 4
gpt4 key购买 nike

我正在将 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<Thing> sortByRating(List<Thing> things){

// custom logic

return things;
};

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

最佳答案

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

如果您使用的是 Java 8,则可以使用其功能对列表进行排序,this文章展示了很好的例子,它需要更多的工作,但看起来就像你所追求的。请注意,为了从 stream 转换至 list你必须包括 .collect(Collectors.toList());stream 的末尾.

例子(取自文章):

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));

关于java - Spring Data JPA - JpaRepository 中的自定义排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33318257/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com