mapper.xml中limit分页参数不能使用计算表达式问题

异常信息:

复制代码
Parsing error in {(pageNum-1)*pageSize} in position 11

这表明在MyBatis XML映射文件中,有一个表达式 (pageNum-1)*pageSize 的语法有问题。

问题分析

这种错误通常发生在以下几种情况:

  1. #{}${}中使用了复杂的算术表达式
  2. XML标签嵌套不正确
  3. 表达式语法错误

解决方案

方案1:检查并修复XML中的表达式

找到你的MyBatis映射文件,检查是否有类似这样的代码:

xml 复制代码
<!-- 错误的写法 -->
SELECT * FROM table LIMIT #{ (pageNum-1)*pageSize }, #{pageSize}

<!-- 或者 -->
SELECT * FROM table LIMIT ${ (pageNum-1)*pageSize }, ${pageSize}

正确的修复方式:

xml 复制代码
<!-- 方案1.1:在Java代码中计算偏移量 -->
<!-- 在调用Mapper方法前计算 -->
int offset = (pageNum - 1) * pageSize;

<!-- Mapper接口 -->
List<...> listAllPurchaseSuppliers(@Param("offset") int offset, @Param("pageSize") int pageSize);

<!-- XML -->
SELECT * FROM table LIMIT #{offset}, #{pageSize}
xml 复制代码
<!-- 方案1.2:使用MySQL的数学运算(如果数据库支持) -->
SELECT * FROM table LIMIT (#{pageNum} - 1) * #{pageSize}, #{pageSize}
xml 复制代码
<!-- 推荐:方案1.3:使用MyBatis的bind标签 -->
<select id="listAllPurchaseSuppliers" resultType="...">
    <bind name="offset" value="(pageNum - 1) * pageSize"/>
    SELECT * FROM table 
    LIMIT #{offset}, #{pageSize}
</select>

方案2:检查完整的SQL映射文件

请检查你的MyBatis XML文件,特别是包含分页逻辑的部分。常见的错误模式:

错误示例:

xml 复制代码
<!-- 错误:在#{}中包含复杂表达式 -->
<select id="listAllPurchaseSuppliers" resultType="...">
    SELECT * FROM table 
    LIMIT #{(pageNum-1)*pageSize}, #{pageSize}
</select>

<!-- 错误:标签嵌套不正确 -->
<if test="condition">
    LIMIT ${(pageNum-1)*pageSize}, #{pageSize}
</if>

正确示例:

xml 复制代码
<!-- 正确:使用bind标签 -->
<select id="listAllPurchaseSuppliers" resultType="...">
    <bind name="offset" value="(pageNum - 1) * pageSize"/>
    SELECT * FROM table 
    WHERE 1=1
    <if test="condition != null">
        AND condition = #{condition}
    </if>
    LIMIT #{offset}, #{pageSize}
</select>

<!-- 正确:在Java中计算 -->
<select id="listAllPurchaseSuppliers" resultType="...">
    SELECT * FROM table 
    LIMIT #{offset}, #{pageSize}
</select>

方案3:使用MyBatis-Plus的分页插件(推荐)

如果你在使用MyBatis-Plus,建议使用其分页插件:

java 复制代码
// 配置分页插件
@Configuration
public class MybatisPlusConfig {
    
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}

// 使用分页查询
@Service
public class BidProjectInfoServiceImpl {
    
    public Page<BidProjectInfo> getList(int pageNum, int pageSize) {
        Page<BidProjectInfo> page = new Page<>(pageNum, pageSize);
        return bidProjectInfoMapper.selectPage(page, null);
    }
}

方案4:检查Mapper接口和方法签名

确保Mapper接口的方法签名正确:

java 复制代码
// 错误的参数使用
List<...> listAllPurchaseSuppliers(@Param("(pageNum-1)*pageSize") int offset, 
                                  @Param("pageSize") int pageSize);

// 正确的参数使用
List<...> listAllPurchaseSuppliers(@Param("pageNum") int pageNum, 
                                  @Param("pageSize") int pageSize);

或者:

java 复制代码
// 使用Page对象
List<...> listAllPurchaseSuppliers(Page<?> page, ...其他参数);

// 或者计算好偏移量
List<...> listAllPurchaseSuppliers(@Param("offset") int offset, 
                                  @Param("pageSize") int pageSize);

方案5:调试和定位问题

添加调试信息来定位具体问题:

xml 复制代码
<!-- 临时添加日志来调试 -->
<select id="listAllPurchaseSuppliers" resultType="...">
    <!-- 调试信息 -->
    <!-- pageNum: ${pageNum} -->
    <!-- pageSize: ${pageSize} -->
    
    <bind name="offset" value="(pageNum - 1) * pageSize"/>
    
    SELECT * FROM table 
    LIMIT #{offset}, #{pageSize}
</select>

具体修复步骤

  1. 首先找到包含(pageNum-1)*pageSize的XML文件
  2. 检查表达式所在的上下文
  3. 根据上述方案进行修复

请提供你的MyBatis XML映射文件内容,特别是包含分页逻辑的部分,这样我可以给出更精确的修复方案。

如果你无法立即找到问题所在,可以尝试搜索整个项目中的(pageNum-1)*pageSize字符串来定位问题代码。

相关推荐
2301_818732063 天前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot
csdn2015_4 天前
generatorConfig.xml 配置 Controller、Service 完整教程
xml·mybatis
特立独行的猫a4 天前
从XML到Compose的UI变革:现代(2026)Android开发指南
android·xml·ui·compose·jetpack
spencer_tseng4 天前
Stream not available [SysDictDataMapper.xml]
xml·java
qq_297574675 天前
MySQL迁移到瀚高数据库 常用转换函数对照表(附XML示例,直接复用)
xml·数据库·mysql
好好研究6 天前
SpringBoot整合SpringMVC
xml·java·spring boot·后端·mvc
从此不归路7 天前
Qt5 进阶【12】JSON/XML 数据协议处理:与后端/配置文件的对接
xml·开发语言·c++·qt·json
方芯半导体8 天前
EtherCAT “通信 + 控制“ 的全国产化控制方案,ESC芯片(FCE1323)与国产MCU芯片功能板解析
xml·网络·单片机·嵌入式硬件·网络协议·机器人·自动化
好好研究8 天前
总结SSM设置欢迎页的方式
xml·java·后端·mvc
R-sz9 天前
mybatis的XML,如何多值匹配,支持单值(=)和多值(IN)查询
xml·mybatis