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

Mybatis 框架 ( 五 ) 分页

4.6.分页

Mybatis-plus 内置分页插件, 并支持多种数据库

官网 : 分页插件 | MyBatis-Plus (baomidou.com)

4.6.1.增加拦截器

通过 @MapperScan 指定 mapper接口的路径

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
@MapperScan("com.yuan.mapper")
public class MybatisPlusConfig {/*** 添加分页插件*/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));//如果配置多个插件,切记分页最后添加//interceptor.addInnerInterceptor(new PaginationInnerInterceptor()); 如果有多数据源可以不配具体类型 否则都建议配上具体的DbTypereturn interceptor;}}

4.6.2.封装分页信息

准备封装用于分页查询的工具类 BrandInfoPage

import lombok.Data;@Data
public class BrandInfoPage {private Integer pageNo = 1;private Integer pageSize = 10;}

4.6.3.serviceImpl

服务层查询

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yuan.entity.BrandInfo;
import com.yuan.mapper.BrandInfoMapper;
import com.yuan.page.BrandInfoPage;
import com.yuan.service.BrandInfoService;
import org.springframework.stereotype.Service;@Service
public class BrandInfoServiceImpl extends ServiceImpl<BrandInfoMapper, BrandInfo>implements BrandInfoService{@Overridepublic IPage<BrandInfo> listForPage(BrandInfoPage page) {IPage<BrandInfo> pageInfo = new Page<>();// 设置页号pageInfo.setCurrent(page.getPageNo());// 设置页大小pageInfo.setSize(page.getPageSize());return baseMapper.selectPage(pageInfo, null);}
}

baseMapper.selectPage(pageInfo, null); 第二个参数为 QueryWrapper 用于条件查询

4.6.4.返回 Controller类

分析数据

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.yuan.entity.BrandInfo;
import com.yuan.page.BrandInfoPage;
import com.yuan.service.BrandInfoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class BrandInfoController {@Autowiredprivate BrandInfoService brandInfoService;@RequestMapping("/brandInfo/query")public IPage<BrandInfo> query(BrandInfoPage page){System.out.println("page = " + page);IPage<BrandInfo> list = brandInfoService.listForPage(page);System.out.println("list = " + list);System.out.println("分页数据集合 = " + list.getRecords());System.out.println("当前页号 = " + list.getCurrent());System.out.println("每页最多多少条 = " + list.getSize());System.out.println("总记录数 = " + list.getTotal());System.out.println("总页数 = " + list.getPages());}
}

4.6.5.增加条件查询

4.6.5.1.修改 page类

import lombok.Data;@Data
public class BrandInfoPage {private Integer pageNo = 1;private Integer pageSize = 10;/*** 中文名 模糊*/private String cnName;/*** 英文名 精确*/private String enName;
}

4.6.5.2.修改ServiceImpl

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yuan.entity.BrandInfo;
import com.yuan.mapper.BrandInfoMapper;
import com.yuan.page.BrandInfoPage;
import com.yuan.service.BrandInfoService;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;@Service
public class BrandInfoServiceImpl extends ServiceImpl<BrandInfoMapper, BrandInfo>implements BrandInfoService{@Overridepublic IPage<BrandInfo> listForPage(BrandInfoPage page) {IPage<BrandInfo> pageInfo = new Page<>();// 设置页号pageInfo.setCurrent(page.getPageNo());// 设置页大小pageInfo.setSize(page.getPageSize());LambdaQueryWrapper<BrandInfo> queryWrapper = new LambdaQueryWrapper<BrandInfo>().like(page.getCnName() != null, BrandInfo::getBrandCnName, page.getCnName()).eq( !StringUtils.isEmpty(page.getEnName()), BrandInfo::getBrandEnName, page.getEnName()).orderByAsc(BrandInfo::getBrandNum);return baseMapper.selectPage(pageInfo, queryWrapper);}
}
http://www.lryc.cn/news/163786.html

相关文章:

  • Python模板注入
  • Java常用的设计模式
  • 攻防世界-WEB-Web_php_include
  • angular中多层嵌套结构的表单如何处理回显问题
  • Leetcode646. 最长数对链
  • Windows 下安装NPM
  • 【ARM CoreLink 系列 2 -- CCI-400 控制器简介】
  • LeetCode(力扣)77. 组合Python
  • uniapp h5 微信缓存,解决版本更新还是旧版本
  • Nacos——Distro一致性协议
  • 大模型参数高效微调PEFT的理解和应用
  • 工作游戏时mfc140u.dll丢失的解决方法,哪个方法可快速修复mfc140u.dll问题
  • 选择排序——直接选择排序
  • 【C++基础】观察者模式(“发布-订阅”模式)
  • 从业多年,我总结出软件测试工程师必须掌握的技能,你不可错过!
  • 【nerfStudio】5-nerfStudio导出3D Mesh模型
  • 重要公告|投票委托已经上线,应该如何选择社区代表?
  • 【操作系统】聊聊进程、线程、协程
  • springboot 下 activiti 7会签配置与实现
  • RK3399平台开发系列讲解(内核调试篇)spidev_test工具使用
  • 点云从入门到精通技术详解100篇-自适应点云局部邻域特征的特征提取与配准(续)
  • VBA技术资料MF52:VBA_在Excel中突出显示前 10 个值
  • leetcode做题笔记134. 加油站
  • Allegro166版本如何在颜色管理器中实时显示层面操作指导
  • 纷享销客入选中国信通院《高质量数字化转型产品及服务全景图》
  • C高级 DAY4
  • C高级day4
  • Java8-17 --- idea2022
  • Mybatis---增删改查
  • 开机性能-如何抓取开机systrace