“完美”解决Mybatis+PageHelper出现SQL语句末尾自动加limit出现SQL语法错误

当使用Mybatis的PageHelper进行分页查询时,可能会遇到SQL语法错误,因为PageHelper会在SQL末尾自动添加`limit`。解决方法是避免SQL末尾已有分号,或者将查询结果包装为子查询来规避。本文提供了一种通过子查询避免两个`limit`冲突的解决方案。
摘要由CSDN通过智能技术生成

问题比较简单,解决方法也比较简单,这里简单描述一下。
具体描述请看这里:问题详细描述

  1. 产生原因
    Mybatis+Pagehelper在执行分页逻辑时时,会默认在你的写的SQL语句后面添加limit,这时会导致出现SQL语法错误。
  2. 解决办法
    大多数是让安全使用PageHelper,或是去掉SQL末尾的分号,但是无法解决一种场景下的问题,如全年级数学成绩前100名做分页,此时若使用数据库排序,则你的SQL末尾就有limit,再整合PageHelper会出现两个limit连在一起,即代码中写的SQL可能为:
select score from xxx order by score desc limit 100

而最终在数据库中执行的SQL语句为:

select score from tbl_score 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值