MyBatis分页时foreach异常

来源:互联网 发布:乌克兰停电 网络攻击 编辑:程序博客网 时间:2024/06/05 20:15
      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。
原创粉丝点击