【日常记录-Mybatis】PageHelper导致语句截断

1. 简介

PageHelper是Mybatis-Plus中的一个插件,主要用于实现数据库的分页查询功能。其核心原理是将传入的页码和条数赋值给一个Page对象,并保存到本地线程ThreadLocal中,接下来,PageHelper会进入Mybatis的拦截器环节,在拦截器中获取并处理刚才保存在ThreadLocal中的分页参数。这些分页参数会与原本的SQL语句和内部已经定义好的SQL进行拼接,从而完成带有分页处理的SQL语句的构建。

2. 现象描述

2.1 代码

复制代码
// 调用位置
PageHelper.startPage(pageNum,pageSize);
List<MyObject> result = customMapper.getList(taskId,name);


// Mapper中方法的定义
List<MyObject> getList(@Param("taskId")String taskId,@Param("name")String name);


// xml定义SQL语句
<select id="getList" resultType="MyObject">
   select * from myTable where task_id = #{taskId}



   <if test="name != null">
       and name= #{name}
   </if>

   order by id desc
</select>

2.2 异常信息

3. 原因

PageHelper在进行SQL语句解析时,若在where子句中遇到连续多于两个的\n,则直接截断返回,导致语句出错。2.1代码中的where子句在task_id=?\n之后,出现连续4个\n导致语句被截断。

4. 解决方案

方案1:where子句中不要出现空行即可;

方案2: 在每个空行中输入空格,避免多个连续\n出现;

相关推荐
码农娟16 小时前
Hutool XML工具-XmlUtil的使用
xml·java
草青工作室16 小时前
java-FreeMarker3.4自定义异常处理
java·前端·python
java1234_小锋16 小时前
Java中读写锁的应用场景是什么?
java·开发语言
闻哥16 小时前
从 AJAX 到浏览器渲染:前端底层原理与性能指标全解析
java·前端·spring boot·ajax·okhttp·面试
「QT(C++)开发工程师」16 小时前
C++ 多种单例模式
java·c++·单例模式
短剑重铸之日16 小时前
《SpringCloud实用版》统一认证授权:Spring Authorization Server + OAuth2 + JWT 生产级方案
java·后端·spring·jwt·oauth2
哲-哲17 小时前
WVP+ZLM搭建碰到问题
java
编程彩机17 小时前
互联网大厂Java面试:从Spring Cloud到分布式事务的技术场景解析
java·spring cloud·微服务·消息队列·分布式事务
黎雁·泠崖17 小时前
Java内部类与匿名内部类:定义+类型+实战应用
java·开发语言
weixin_4365250717 小时前
若依多租户版: 页面新增菜单, 执行菜单SQL
前端·数据库·sql