SSM项目实战-后端-日程列表查询实现

1、ScheduleController.java

java 复制代码
package com.atguigu.schedule.controller;
import com.atguigu.schedule.dto.Result;
import com.atguigu.schedule.service.ScheduleService;
import com.atguigu.schedule.vo.ScheduleQueryVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/schedule")
@CrossOrigin
public class ScheduleController {
    @Autowired
    private ScheduleService scheduleService;

    @GetMapping("/{pageNum}")
    public Result list(@PathVariable Integer pageNum, Integer uid) {
        ScheduleQueryVo queryVo = new ScheduleQueryVo(uid,pageNum);
        return Result.ok(scheduleService.getSchedulePageInfo(queryVo));
    }

}

2、ScheduleQueryVo.java

java 复制代码
package com.atguigu.schedule.vo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
//日程的查询条件封装成一个java对象,我们将这样的对象称之为查询条件对象(Query Object)
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ScheduleQueryVo {
    private Integer uid;
    private Integer pageNum;   //页码:显示第几页
    private Integer pageSize = 3;  //页大小

    public ScheduleQueryVo(Integer uid, Integer pageNum) {
        this.uid = uid;
        this.pageNum = pageNum;
    }
}

3、ScheduleServiceImpl.java

java 复制代码
package com.atguigu.schedule.service.impl;
import com.atguigu.schedule.mapper.ScheduleMapper;
import com.atguigu.schedule.pojo.Schedule;
import com.atguigu.schedule.service.ScheduleService;
import com.atguigu.schedule.vo.ScheduleQueryVo;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
@Service
@Transactional
public class ScheduleServiceImpl implements ScheduleService {

    @Autowired
    private ScheduleMapper scheduleMapper;

    @Override
    @Transactional
    public PageInfo<Schedule> getSchedulePageInfo(ScheduleQueryVo queryVo) {
        PageHelper.startPage(queryVo.getPageNum(), queryVo.getPageSize());
        List<Schedule> scheduleList = scheduleMapper.getScheduleList(queryVo.getUid());
        return new PageInfo<>(scheduleList);
    }
}

4、ScheduleMapper.java

java 复制代码
package com.atguigu.schedule.mapper;
import com.atguigu.schedule.pojo.Schedule;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public interface ScheduleMapper {
    List<Schedule> getScheduleList(Integer sysUserId);
}

5、ScheduleMapper.xml

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace等于mapper接口类的全限定名,这样实现对应 -->
<mapper namespace="com.atguigu.schedule.mapper.ScheduleMapper">

    <select id="getScheduleList" resultType="Schedule">
        select * from sys_schedule where uid = #{value}
    </select>
</mapper>

6、PageHelper.startPage()

PageHelper.startPage()是MyBatis-Plus中的一个分页插件,用于开启分页操作。

在MyBatis-Plus中,分页插件PageHelper可以自动对SQL语句进行分页处理,无需手动编写分页代码。PageHelper.startPage()方法的作用是标记当前请求为分页请求,并初始化分页参数。

通过调用PageHelper.startPage(),可以指定分页参数,如每页显示记录数、当前页码等。这些参数将被封装为一个分页对象Page,并将其传递给后续的查询操作。使用Page对象可以获取查询结果列表以及一些分页信息,如总记录数、总页数等。

例如,以下代码演示了如何使用PageHelper.startPage()开启分页:

java 复制代码
// 初始化分页参数  
int pageNum = 1; // 当前页码  
int pageSize = 10; // 每页显示记录数  
  
// 开启分页  
PageHelper.startPage(pageNum, pageSize);  
  
// 执行查询操作  
List<User> userList = userMapper.selectList(null);  
  
// 获取分页信息  
Page<User> page = new Page<>(pageNum, pageSize);  
page.setCount(userMapper.selectCount(null)); // 获取总记录数

通过调用PageHelper.startPage(),可以方便地实现分页查询操作,并获取查询结果和分页信息。

相关推荐
戮戮30 分钟前
Spring Cloud Gateway 零拷贝参数校验:一种高性能网关架构实践
java·网络·架构·gateway
alengan43 分钟前
cocos自动编译-Android自动出apk包
java·eclipse
漫霂1 小时前
二叉树的统一迭代遍历
java·算法
文静小土豆1 小时前
K8s 滚动更新在 Java 应用中的实践与优化
java·容器·kubernetes
HSunR1 小时前
java springboot3 后端 基础框架
java·开发语言
七夜zippoe1 小时前
Java技术未来展望:GraalVM、Quarkus、Helidon等新趋势探讨
java·开发语言·python·quarkus·graaivm·helidon
枫叶落雨2221 小时前
ClassPathXmlApplicationContext
java·开发语言
草莓熊Lotso1 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·linux·运维·服务器·数据库·c++·mysql
gelald1 小时前
Spring Boot - 自动配置原理
java·spring boot·后端
hssfscv1 小时前
软件设计师下午题六——Java的各种设计模式
java·算法·设计模式