MyBatis-Plus分页查询方式

分页查询基本方式

java 复制代码
@SpringBootTest(classes = LearningApplication.class)
public class MPTest {
    @Autowired
    ILearningLessonService lessonService;

    @Test
    public void test(){
        /**
         * Page<LearningLesson>:MyBatisPlus提供的分页对象
         * 1:当前页数
         * 2:每页显示的记录数
         */
        Page<LearningLesson> page = new Page<>(1, 2);

        /**
         * wrapper:使用Lambda表达式构造的查询条件。
         */
        LambdaQueryWrapper<LearningLesson> wrapper = new LambdaQueryWrapper<>();
        //用户 id 等于 2 的记录
        wrapper.eq(LearningLesson::getUserId, 2);
        
        //业务层的服务类调用分页查询方法   (page, wrapper) -> (分页对象,查询条件)
        lessonService.page(page, wrapper);
    }

按照某一字段升序或者降序排序

java 复制代码
	@Test
    public void test1(){
        Page<LearningLesson> page = new Page<>(1, 2);

		/**
		*构建按照什么字段进行排序
		*/
        List<OrderItem> itemList = new ArrayList<>();
        //指定排序的对象
        OrderItem item = new OrderItem();
        item.setColumn("latest_learn_time");//按什么latest_learn_time字段排序
        item.setAsc(false);//降序排序
        itemList.add(item);
        //排序条件添加到分页对象中
        page.addOrder(itemList);

        LambdaQueryWrapper<LearningLesson> wrapper = new LambdaQueryWrapper<>();
        wrapper.eq(LearningLesson::getUserId, 2);
        lessonService.page(page, wrapper);
    }

简化写法

java 复制代码
    @Test
    public void test2(){
    	//分页对象
        Page<LearningLesson> page = new Page<>(1, 2);
		
		//构建分页查询条件
        List<OrderItem> itemList = new ArrayList<>();
        OrderItem item = new OrderItem();
        item.setColumn("latest_learn_time");
        item.setAsc(false);
        itemList.add(item);
        page.addOrder(itemList);
        
        //构造查询条件和调用分页查询方法一起。
        lessonService.lambdaQuery()
                .eq(LearningLesson::getUserId,2)
                .page(page);
    }
相关推荐
沐雪轻挽萤4 分钟前
1. C++17新特性-序章
java·c++·算法
殷紫川7 分钟前
Spring AI 整合火山引擎豆包向量库搭建企业知识库:我踩过的 10 个致命坑与终极解决方案
java·ai编程
呆呆在发呆.11 分钟前
JavaEE初阶
java·jvm·网络协议·学习·udp·java-ee·tcp
算.子11 分钟前
【Spring 实战】Spring AI 进阶专题:Token 成本优化与 Structured Output
java·人工智能·spring
Gopher_HBo17 分钟前
ReentrantReadWriteLock源码讲解
java·后端
农村小镇哥19 分钟前
PHP数据传输流+上传条件+上传步骤
java·开发语言·php
wuxinyan12320 分钟前
Java面试题48:一文深入了解java设计模式
java·设计模式·面试
济源IT小伙一枚24 分钟前
⚡️硬核实战:Spring AI + Ollama 从零搭建私有化多角色 AI 助手|RAG 知识库 + MCP 控制台全实现
java·人工智能·spring
李少兄26 分钟前
Windows 安装 Maven 详细教程(含镜像与本地仓库配置)
java·windows·maven
电商API&Tina27 分钟前
淘宝 / 京东关键词搜索 API 接入与实战用途教程|从 0 到 1 搭建电商选品 / 比价 / 爬虫替代系统
java·开发语言·数据库·c++·python·spring