当前位置: 首页 > news >正文

Mybatis Plus中使用LambdaQueryWrapper进行分页以及模糊查询对比传统XML方式进行分页

传统的XML分页以及模糊查询操作

传统的XML方式只能使用limit以及offset进行分页,通过判断name和bindState是否为空,不为空则拼接条件。

List<SanitationCompanyStaff> getSanitationStaffInfo(@Param("name") String name,@Param("bindState") String bindState,@Param("current") Long current,@Param("size") Long size);
<select id="getSanitationStaffInfo" resultType="com.yutu.garden.entity.SanitationCompanyStaff">select * from sanitation_company_staffwhere 0 = 0<if test="name != null and name != ''">and name like concat('%', #{name}, '%')</if><if test="bindState != null and bindState != ''">and bind_state like concat('%', #{bindState}, '%')</if>limit 5 offset 0
</select>

Mybatis Plus分页以及模糊查询操作

只需要在Service实现类中直接调用Mybatis Plus的方法即可进行操作。

/*** 获取环卫工列表数据* @param name:名字* @param bindState:绑定状态* @param current:页码* @param size:每页大小* @return*/
@Override
public Page<SanitationCompanyStaff> getSanitationStaffInfo(String name,String bindState,Long current,Long size) {LambdaQueryWrapper<SanitationCompanyStaff> wrapper = new LambdaQueryWrapper<>();//如果前端传的name不为空,则进行like模糊查询if (StringUtils.isNotEmpty(name)){wrapper.like(SanitationCompanyStaff::getName,name);}//如果前端传的bindState不为空,则进行eq匹配if (StringUtils.isNotEmpty(bindState)){wrapper.eq(SanitationCompanyStaff::getBindState,bindState);}//通过current、size进行分页Page<SanitationCompanyStaff> sanitationStaffInfoPage = new Page<>(current,size);this.page(sanitationStaffInfoPage,wrapper);return sanitationStaffInfoPage;
}

return Page<SanitationCompanyStaff>类型可以得到数据的总数,你也可以通过.getRecords()方式获取List集合

在这里插入图片描述

这样子,我们就可以通过Mybatis Plus得到分页数据了!

http://www.lryc.cn/news/132935.html

相关文章:

  • vue中push和resolve的区别
  • 详解RFC 3550文档-1
  • Go 与 Rust
  • Android Studio实现读取本地相册文件并展示
  • python的全局解释锁(GIL)
  • 小程序swiper一个轮播显示一个半内容且实现无缝滚动
  • 【自然语言处理】关系抽取 —— SimpleRE 讲解
  • 【O2O领域】Axure外卖订餐骑手端APP原型图,外卖众包配送原型设计图
  • DataGridView keydown事件无法在C#中工作
  • 【ElasticSearch】一键安装ElasticSearch与Kibana以及解决遇到的问题
  • 电商数据采集和数据分析
  • react 11之 router6路由 (两种路由模式、两种路由跳转、两种传参与接收参数、嵌套路由,layout组件、路由懒加载)
  • Golang 基础语法问答
  • 冠达管理:哪里查中报预增?
  • docker安装Oracle11gR2
  • unity 之 Input.GetMouseButtonDown 的使用
  • 链游再进化 Web3版CSGO来袭
  • WordPress用于您的企业网站的优点和缺点
  • ~600行ANSI C代码实现RISC-V CPU核
  • 【从零学习python 】55.Python中的序列化和反序列化,JSON与pickle模块的应用
  • 【C++】详解内存中的堆和栈
  • QCustomPlot横坐标为毫秒级的时间轴数据展示的实时刷新数据功能
  • STM32/AT32 MCO管脚输出时钟配置
  • “SRP模型+”多技术融合在生态环境脆弱性评价模型构建、时空格局演变分析与RSEI 指数的生态质量评价
  • 【大虾送书第六期】搞懂大模型的智能基因,RLHF系统设计关键问答
  • 超越函数界限:探索JavaScript函数的无限可能
  • PHP实现轻量级WEB服务器接收HTTP提交的RFID刷卡信息并回应驱动读卡器显示播报语音
  • Neo4j之with基础
  • 60页数字政府智慧政务大数据资源平台项目可研方案PPT
  • 循环神经网络RNN完全解析:从基础理论到PyTorch实战