浅谈mybatisPlus的Ipage分页和map参数的问题

 更新时间:2021年12月20日 14:16:20   作者:L-岁月染过的梦  
这篇文章主要介绍了mybatisPlus的Ipage分页和map参数的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mybatisPlus的Ipage分页和map参数

前提:先有一个map类型的参数

Map params= new HashMap();
params.put("name","张三");
params.put("age","23");

第一种情况

List<Map<String,Object>> selectList(@Param("params") HashMap  params);

这种也是我们最常用的一种

不管参数是什么类型都可以省略,但是要写上返回值类型(根据自己的情况)

<select id="selectList" resultType="java.util.HashMap">

取值时只需要在xml文件内用map中的键值来取数据

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

第二种情况

dao层声明参数和返回值类型

IPage selectAll(IPage page,@Param("params") HashMap  params);
<select id="selectAll" resultType="java.util.HashMap">

一般我们在xxx.xml里面取map的值都是直接通过#{键}来取的

但是当传入的参数不止一个时,取map里面的值就需要用参数去取

<if test="params.name != '' and params.name != null">
    AND name=#{params.name}
</if>
<if test="params.age != '' and params.age != null">
    AND age=#{params.age}
</if>

这个params就是dao层传入的map类型的参数

直接通过键来取值无法取到值

mybatisPlus IPage分页常见问题(坑)

观前提示:

本文所使用的IDEA版本为ultimate 2019.1,JDK版本为1.8.0_141。

1.TooManyResultsException

最近在使用Mybatis-plus的IPage插件分页时,出现了以下的莫名其妙的错误

Resolved [org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 6]

然后检查我写的Controller、Service、Mapper、Mapper.xml,结果还是一无所获,以下是我的Mapper和Mapper.xml(大致内容一致)

Mapper

public interface ExampleMapper {
    IPage<EntityDto> selectEntityAndPage(@Param("param") Entity param, Page<Entity> page);
}

Mapper.xml的select部分

  <select id="selectEntityAndPage" parameterType="cn.com.example.enetity.Entity " resultType="cn.com.example.dto.EntityDto">
    select id, name from table
  </select>

百度了一下才发现了这个深坑

mybatis-plus 中page参数不在第一个位置,返回的结果集接收对象不被认为是一个集合,而放在第一位就没有问题。

所以我改写了Mapper参数的顺序

IPage<EntityDto> selectEntityAndPage(Page<Entity> page, @Param("param") Entity param);

问题解决。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于SpringBoot中事务失效的几种情况

    关于SpringBoot中事务失效的几种情况

    这篇文章主要介绍了关于SpringBoot中事务失效的几种情况,Spring AOP默认使用动态代理,会给被代理的类生成一个代理类,事务相关的操作都通过代理来完成,使用内部方法调用时,使用的是实例调用,没有通过代理类调用方法,因此事务不会检测到失败,需要的朋友可以参考下
    2023-08-08
  • SpringMVC处理multipart请求的示例代码

    SpringMVC处理multipart请求的示例代码

    本篇文章主要介绍了SpringMVC处理multipart请求的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • SpringBoot返回前端Long类型字段丢失精度问题及解决方案

    SpringBoot返回前端Long类型字段丢失精度问题及解决方案

    Java服务端返回Long整型数据给前端,JS会自动转换为Number类型,本文主要介绍了SpringBoot返回前端Long类型字段丢失精度问题及解决方案,感兴趣的可以了解一下
    2024-03-03
  • Java使用jxl包写Excel文件适合列宽实现

    Java使用jxl包写Excel文件适合列宽实现

    用jxl.jar包,读写过Excel文件。也没有注意最适合列宽的问题,但是jxl.jar没有提供最适合列宽的功能,上次用到写了一下,可以基本实现最适合列宽。
    2013-11-11
  • mybatis实现遍历Map的key和value

    mybatis实现遍历Map的key和value

    这篇文章主要介绍了mybatis实现遍历Map的key和value方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • java Arrays快速打印数组的数据元素列表案例

    java Arrays快速打印数组的数据元素列表案例

    这篇文章主要介绍了java Arrays快速打印数组的数据元素列表案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Spring Data JPA映射自定义实体类操作

    Spring Data JPA映射自定义实体类操作

    这篇文章主要介绍了Spring Data JPA映射自定义实体类操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Java如何生成带网站链接(URL)的二维码

    Java如何生成带网站链接(URL)的二维码

    自从微信扫描出世,二维码扫描逐渐已经成为一种主流的信息传递和交换方式,这篇文章主要给大家介绍了关于Java如何生成带网站链接(URL)的二维码的相关资料,文中通过图文实例代码介绍的非常详细,需要的朋友可以参考下
    2021-07-07
  • java适配器模式之万物拟人化

    java适配器模式之万物拟人化

    本文详细介绍了什么是适配器模式,适配器模式的种类以及各种类的详细讲解等,需要学习该知识点的小伙伴可以参考这篇文章
    2021-08-08
  • Java修改图片大小尺寸的简单实现

    Java修改图片大小尺寸的简单实现

    这篇文章主要介绍了Java修改图片大小尺寸的简单实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09

最新评论