Spring 引导@Query:按命名参数排序



我喜欢我的 REST-API 端点可以按不同的模型属性进行排序。我已经用谷歌搜索了很多解决方案,但没有一个符合我的要求。

我喜欢在我的PagingAndSortingRepository界面中拥有以下内容:

    @Query(value = "SELECT v FROM vwFact v WHERE v.applicationId like %:applicationId% " +
            "and (v.mdName01 like :mdName% or v.mdName02 like :mdName% or v.mdName03 like :mdName% or v.mdName04 like :mdName%) " +
            "ORDER BY :sortParam :sortDir"
    )
    Page<vwFact> findAllByApplicationIdAndMdName(
            @Param(value = "applicationId") String applicationId,
            @Param(value = "mdName") String mdName,
            @Param(value = "sortParam") String sortParam,
            @Param(value = "sortDir") String sortDir,
            Pageable pageable
    );

是否有机会实现这一点,或者我必须以另一种方式做到这一点。你会评论什么?

Pageable 有一个选项来指定如何对结果进行排序(方向和参数)。

PageRequest(int page, int size, Sort sort) 
PageRequest(int page, int size, Sort.Direction direction, String... properties) 

相关内容

  • 没有找到相关文章

最新更新