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

spring boot中实现手动分页

手动分页

  1. UserMapper.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 userorder by idlimit #{pageSize}offset #{offset}</select>
</mapper>
  1. UserMapper.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
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
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;@Autowiredpublic UserServiceImpl(UserMapper userMapper) {this.userMapper = userMapper;}// 查询所有用户信息@Overridepublic List<UserBean> queryAllUser(Map<String, Object> params) {return userMapper.getAllUsers(params);}
}
  1. UserController.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;@Autowiredpublic 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);}
}
http://www.lryc.cn/news/525055.html

相关文章:

  • 【优选算法】5----有效三角形个数
  • C++打字模拟
  • 最新版pycharm如何配置conda环境
  • UML-对象图(Object Diagram)
  • Jmeter 动态参数压力测试时间段预定接口
  • 超大型集团合并报表数智管理转型
  • [MCAL]Mcu配置
  • Qt基础项目篇——Qt版Word字处理软件
  • 算法刷题笔记——图论篇
  • Java空指针异常处理:判空、Optional与Assert解析
  • 【vim】vim编辑器如何设置行号
  • MySQL可直接使用的查询表的列信息
  • 在线宠物用品|基于vue的在线宠物用品交易网站(源码+数据库+文档)
  • 《安富莱嵌入式周报》第349期:VSCode正式支持Matlab调试,DIY录音室级麦克风,开源流体吊坠,物联网在军工领域的应用,Unicode字符压缩解压
  • 使用LabVIEW的History功能实现队列数据的读取而不清空
  • 电脑如何访问手机文件?
  • SpringBoot实现定时任务,使用自带的定时任务以及调度框架quartz的配置使用
  • java上传图片功能实现
  • 73,【5】BUUCTF WEB [网鼎杯 2020 玄武组]SSRFMe(未解出)
  • 【FreeRTOS 教程 一】任务结构体及其基础创建使用
  • 深入剖析 JVM 内存模型
  • 解决DeepSeek-R1模型在Cursor中使用报错的问题
  • ASP.NET Core 6.0 如何处理丢失的 Startup.cs 文件
  • Java如何向http/https接口发出请求
  • 数据分析 变异系数
  • 利用免费GIS工具箱实现高斯泼溅切片,将 PLY 格式转换为 3dtiles
  • 面试-二维数组
  • 如何使用 findIndex() 方法查找数组中的第一个匹配元素的索引?
  • 5. 马科维茨资产组合模型+政策意图AI金融智能体(Qwen-Max)增强方案(理论+Python实战)
  • Centos类型服务器等保测评整/etc/pam.d/system-auth