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);
    }
相关推荐
m0_7482368341 分钟前
Spring Boot日志:从Logger到@Slf4j的探秘
java·spring boot·spring
码字哥2 小时前
EasyExcel设置表头上面的那种大标题(前端传递来的大标题)
java·服务器·前端
customer085 小时前
【开源免费】基于SpringBoot+Vue.JS加油站管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·java-ee·maven
Hello.Reader5 小时前
Spring Retry 与 Redis WATCH 结合实现高并发环境下的乐观锁
java·redis·spring
西岭千秋雪_5 小时前
设计模式の单例&工厂&原型模式
java·单例模式·设计模式·简单工厂模式·工厂方法模式·抽象工厂模式·原型模式
fanchael_kui5 小时前
使用elasticsearch-java客户端API生成DSL语句
java·大数据·elasticsearch
m0_748256565 小时前
[CTF夺旗赛] CTFshow Web1-14 详细过程保姆级教程~
java
T.O.P116 小时前
Spring&SpringBoot常用注解
java·spring boot·spring
O(1)的boot6 小时前
微服务的问题
java·数据库·微服务
一个略懂代码的程序员6 小时前
Redis01
java·redis