MyBatis使用分页插件时并且查询条件包含foreach时,分页插件在执行count语句时会抛出异常,报参数为空异常。项目中使用到了MyBatisPlus,分页也是用的它的PaginationInterceptor,项目中的版本为1.3.6。分页插件会新增一个COUNT的SQL,并复制原BoundSql对象,然后使用DefaultParameterHandler.setParameters给COUNT语句设值。foreach过程中产生的参数变量是放在AdditionalParameter中,但复制BoundSql时并没有复制其中的additionalParameters字段,而由foreach产生的参数是存放在additionalParameters中,所以导致参数空异常。解决方案就是反射获取到additionalParameters字段的值并设置到新产生的BoundSql中去。此Bug在高版本已修复,它继承实现了一个MybatisDefaultParameterHandler去设置COUNT语句的值,直接使用原始BoundSql,首先是直接到BoundSql中找值,找不到时还会反射additionalParameters。
MyBatis分页时foreach异常
最新推荐文章于 2025-03-12 15:51:07 发布
在使用MyBatisPlus的分页插件PaginationInterceptor时,若查询条件包含foreach,则执行count语句时会因参数为空抛出异常。原因是复制BoundSql对象时未复制additionalParameters字段,导致foreach产生的参数丢失。可通过反射获取并设置additionalParameters解决。高版本已修复此问题。
7193





