Cannot use native queries with dynamic sorting and/or pagination even if I have specified the count

使用Springdata Jpa 分页功能时报的错,解决办法:

在sql语句中加  ORDER BY ?#{#pageable} 就可以了

如下:

@Query(
        value = "select * from paper_entry where owner is null or owner = ?1 ORDER BY ?#{#pageable}",
        countQuery = "select count(*) from paper_entry where owner is not null or owner = ?1 ORDER BY ?#{#pageable}",
        nativeQuery = true)
    Page findAll(Long userId, Pageable pageable);

如果查询时使用的是递归查询且使用了Springdata的排序功能,如

select * from (SELECT CC.* FROM JOB_T CC START WITH CC.PRID in (?1) CONNECT BY PRIOR CC.RID= CC.PRID) CC where CC.wjlx='1' order by ?#{#pageable}

理解的三步:

1、注意别名使用,加上了排序后,?#{#pageable}运行出的语句拿的是括号内中的别名“CC” ——> order by CC.需排序字段(可自行去尝试运行,看运行后的语句)

2、故将递归后查出的结果别名设置成“CC”,使排序生效

3、若更改递归查询内JOB_T表的别名,查询结果的别名也一并更改,否则排序失效。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值