spring boot中实现手动分页

手动分页

  1. UserMapper.xml
xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.mayanan.restapi.mapper.UserMapper">
    <!-- 在复杂的sql查询中,使用resultMap是最佳实践, 它能清晰的定义嵌套对象的映射规则 -->
    <resultMap id="userResultMap" type="cn.mayanan.restapi.bean.UserBean">
        <id column="id" property="id" />
        <result column="name" property="username" />
        <result column="password" property="password" />
    </resultMap>

    <!-- 查询所有用户信息 -->
    <select id="getAllUsers" parameterType="map" resultMap="userResultMap">
        select id, name, password from user
        order by id
        limit #{pageSize}
        offset #{offset}
    </select>
</mapper>
  1. UserMapper.java
java 复制代码
package cn.mayanan.restapi.mapper;

import org.apache.ibatis.annotations.Mapper;
import cn.mayanan.restapi.bean.UserBean;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

@Mapper
public interface UserMapper {
    List<UserBean> getAllUsers(Map<String, Object> params);
}
  1. UserService.java
java 复制代码
package cn.mayanan.restapi.service;

import cn.mayanan.restapi.bean.UserBean;

import java.util.List;
import java.util.Map;

public interface UserService {
    UserBean queryUserById(int id);

    List<UserBean> queryAllUser(Map<String, Object> params);
}
  1. UserServiceImpl.java
java 复制代码
package cn.mayanan.restapi.serviceImpl;

import cn.mayanan.restapi.bean.UserBean;
import cn.mayanan.restapi.mapper.UserMapper;
import cn.mayanan.restapi.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;
import java.util.Map;

@Service
public class UserServiceImpl implements UserService {
    // 将Dao注入Service层
    private final UserMapper userMapper;
    @Autowired
    public UserServiceImpl(UserMapper userMapper) {
        this.userMapper = userMapper;
    }

    // 查询所有用户信息
    @Override
    public List<UserBean> queryAllUser(Map<String, Object> params) {
        return userMapper.getAllUsers(params);
    }
}
  1. UserController.java
java 复制代码
package cn.mayanan.restapi.controller;

import cn.mayanan.restapi.bean.UserBean;
import cn.mayanan.restapi.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

// @RestController是一个方便的注解,它结合了@Controller和@ResponseBody注解
@RestController  // 标注为Rest控制器
@RequestMapping("/api")  // 定义基础路径
public class MyRestController {
    // 将Service注入Controller层
    private final UserService userService;
    @Autowired
    public MyRestController(UserService userService) {
        this.userService = userService;
    }

    // 查询所有用户信息
    @GetMapping("/users")
    public List<UserBean> showUsers(
            @RequestParam(value = "pageSize", defaultValue = "1") int pageSize,
            @RequestParam(value = "pageNum", defaultValue = "1") int pageNum
    ) {
        System.out.println("pageSize: " + pageSize + ", pageNum: " + pageNum);
        // 手动分页
        Map<String, Object> map = new HashMap<>();
        int offset = (pageNum - 1) * pageSize;
        map.put("pageSize", pageSize);
        map.put("offset", offset);
        return userService.queryAllUser(map);
    }
}
相关推荐
xiezhr几秒前
spring官宣接入deepseek,真的太香了~
java·ai·deepseek
大吱佬2 分钟前
解决每次 Maven Rebuild 后 Java 编译器版本变为 1.5
java·开发语言·maven
B站计算机毕业设计超人2 分钟前
计算机毕业设计SpringBoot+Vue.jst0甘肃非物质文化网站(源码+LW文档+PPT+讲解)
java·vue.js·spring boot·后端·spring·intellij-idea·课程设计
why技术32 分钟前
可以说是一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
后端·面试
m0_7482546636 分钟前
定时任务特辑 Quartz、xxl-job、elastic-job、Cron四个定时任务框架对比,和Spring Boot集成实战
java·spring boot·后端
海边漫步者1 小时前
Idea2024中搭建JavaFX开发环境并创建运行项目
java·intellij-idea·javafx
diemeng11191 小时前
2024系统编程语言风云变幻:Rust持续领跑,Zig与Ada异军突起
开发语言·前端·后端·rust
Warren981 小时前
Springboot中分析SQL性能的两种方式
java·spring boot·后端·sql·mysql·intellij-idea
Distance失落心2 小时前
idea任意版本的安装
java·ide·java-ee·eclipse·intellij-idea
Aphelios3802 小时前
Linux 下 VIM 编辑器学习记录:从基础到进阶(下)
java·linux·学习·编辑器·vim