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

2023-01-21 0 4,704

目录

mybatisPlusIpage分页和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);

问题解决。

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

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 浅谈mybatisPlus的Ipage分页和map参数的问题 http://www.20zxx.cn/463410/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务