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

哪里需要人做钓鱼网站维力安网站建设公司

哪里需要人做钓鱼网站,维力安网站建设公司,wordpress卡在 wp,软文街官方网站Spring Boot集成PageHelper:轻松实现数据库分页功能 1. 为什么需要分页? 分页是处理大数据量查询的核心技术,其重要性体现在: 性能优化:避免单次查询返回过多数据导致内存溢出或响应延迟。用户体验:前端展…

Spring Boot集成PageHelper:轻松实现数据库分页功能


1. 为什么需要分页?

分页是处理大数据量查询的核心技术,其重要性体现在:

  • 性能优化:避免单次查询返回过多数据导致内存溢出或响应延迟。
  • 用户体验:前端展示分页导航,用户可快速定位目标数据。
  • 网络开销:减少不必要的数据传输,节省带宽。

传统分页的痛点

  • 复杂SQL:需手动编写LIMITOFFSET等分页语句,尤其多表联查时易出错。
  • 维护困难:分页逻辑散落在多个DAO层方法中,修改分页规则需全局调整。

2. PageHelper简介

PageHelper是MyBatis的物理分页插件,核心功能包括:

  • 自动分页:拦截SQL并动态添加分页语句,无需修改原查询逻辑。
  • 多数据库支持:自动识别MySQL、Oracle等方言,生成对应分页语法。
  • 无缝集成:与Spring Boot和MyBatis深度整合,仅需简单配置即可使用。

优势对比

方案代码量可维护性跨数据库支持
手写SQL分页
PageHelper
Spring Data JPA中等

3. 环境准备

步骤1:创建Spring Boot项目
使用 Spring Initializr 生成项目,勾选:

  • MyBatis Framework
  • MySQL Driver(或其他数据库驱动)

步骤2:添加PageHelper依赖

<!-- Maven -->
<dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.4.7</version>
</dependency>

步骤3:配置数据源与分页参数

# application.yml
spring:datasource:url: jdbc:mysql://localhost:3306/demo?useSSL=falseusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Drivermybatis:mapper-locations: classpath:mapper/*.xmlpagehelper:helperDialect: mysql    # 指定数据库方言reasonable: true        # 页码越界自动修正(如pageNum=100时返回最后一页)supportMethodsArguments: true  # 支持通过方法参数传递分页条件

4. 核心实现

4.1 创建实体类和Mapper接口

// User.java
@Data
public class User {private Long id;private String name;private String email;
}// UserMapper.java
@Mapper
public interface UserMapper {List<User> selectAllUsers();
}

4.2 编写Mapper XML文件

<!-- resources/mapper/UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper"><select id="selectAllUsers" resultType="User">SELECT id, name, email FROM user</select>
</mapper>

4.3 Service层实现分页查询

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public PageInfo<User> getUsers(int pageNum, int pageSize) {// 关键:调用startPage后第一个查询自动分页PageHelper.startPage(pageNum, pageSize);List<User> users = userMapper.selectAllUsers();return new PageInfo<>(users);}
}

4.4 Controller层暴露API

@RestController
@RequestMapping("/api/users")
public class UserController {@Autowiredprivate UserService userService;@GetMappingpublic ResponseEntity<PageInfo<User>> listUsers(@RequestParam(defaultValue = "1") int page,@RequestParam(defaultValue = "10") int size) {PageInfo<User> pageInfo = userService.getUsers(page, size);return ResponseEntity.ok(pageInfo);}
}

4.5 分页结果示例
请求 GET /api/users?page=2&size=5 返回:

{"total": 50,"pageNum": 2,"pageSize": 5,"pages": 10,"list": [{"id": 6, "name": "User6", "email": "user6@example.com"},...]
}

5. 高级配置

5.1 自定义分页参数

pagehelper:params: count=countSql  # 将COUNT查询转换为COUNT_SQL优化语句page-size-zero: true    # 允许pageSize=0时返回全部结果max-page-size: 100      # 限制每页最大数据量

5.2 多数据源分页

@Configuration
public class DataSourceConfig {@Bean@ConfigurationProperties("spring.datasource.db1")public DataSource db1DataSource() {return DataSourceBuilder.create().build();}@Beanpublic SqlSessionFactory db1SqlSessionFactory() throws Exception {SqlSessionFactoryBean factory = new SqlSessionFactoryBean();factory.setDataSource(db1DataSource());// 配置PageHelper插件PageInterceptor pageInterceptor = new PageInterceptor();Properties props = new Properties();props.setProperty("helperDialect", "mysql");pageInterceptor.setProperties(props);factory.setPlugins(pageInterceptor);return factory.getObject();}
}

5.3 与Spring Data JPA结合

  • 适用场景:同时需要JPA的便捷CRUD和复杂SQL分页。
  • 实现方式:在JPA Repository中注入MyBatis Mapper,混合使用。

6. 常见问题与解决方案

问题1:分页失效

  • 排查步骤
    1. 确认PageHelper.startPage()在查询调用。
    2. 检查是否配置了多个MyBatis插件导致拦截顺序冲突。

问题2:SQL注入风险

  • 防御措施
    • 避免直接拼接SQL参数,如ORDER BY ${sortField}
    • 使用PageHelperorderBy方法安全排序:
      PageHelper.startPage(1, 10).setOrderBy("id desc");
      

问题3:分页结果不准确

  • 原因
    • 查询包含GROUP BY或子查询时,自动生成的COUNT语句可能错误。
  • 解决:手动指定COUNT查询:
    <select id="selectAllUsers" resultType="User">SELECT id, name FROM user
    </select>
    <select id="selectAllUsers_COUNT" resultType="Long">SELECT COUNT(1) FROM user
    </select>
    

7. 总结与扩展

适用场景

  • 后台管理系统数据表格展示
  • 移动端APP的分页加载
  • 大数据量报表分批处理

扩展学习

  • PageHelper官方文档
  • MyBatis动态SQL技巧
  • 实战案例:电商订单分页查询

流程图:PageHelper分页流程

Client Controller Service PageHelper MyBatis DB 请求/api/users?page=2&size=10 调用getUsers(2,10) startPage(2,10) 执行selectAllUsers() 拦截SQL 发送SELECT ... LIMIT 10 OFFSET 10 返回分页数据 包装为PageInfo 返回PageInfo 响应JSON Client Controller Service PageHelper MyBatis DB

避坑指南

  1. 索引优化:确保分页字段(如id)有索引,避免OFFSET过大时性能下降。
  2. 参数校验:校验pageNumpageSize的合法性,防止负数或超大值。
  3. 线程安全PageHelper.startPage()基于ThreadLocal,需注意异步场景下的数据隔离。

通过本文,您已掌握Spring Boot集成PageHelper的核心技巧。立即实践,让分页功能从此高效又优雅! 🚀

http://www.dtcms.com/a/471782.html

相关文章:

  • 备案的网站必须打开吗seo是什么意思揉若湖南岚鸿专注
  • 湖南长信建设集团网站wordpress 怎么改中文字体
  • Kafka11-知识补充
  • 印象网站建设苏州制作网站的有几家
  • 火车票网站建设多少钱交通运输企业标准建设网站
  • 做公众号网站棋牌游戏软件开发公司
  • 钓鱼网站二维码制作软件正邦设计作品
  • 01-Python简介与环境搭建-导读
  • 青岛手机网站设计公司成都网站建设推来客网站系统报价
  • 深圳网站设计专业乐云seo即刻搜索收录网站
  • 遵义酷虎网站开发茶庄网站模板
  • 惠州网站seo排名优化贝贝网网站开发背景
  • 捷智算L40云主机租赁:即开即用、弹性伸缩,Docker部署零等待
  • [算法练习]Day 7: 变长滑动窗口
  • 才做的网站怎么搜不到做企业礼品的网站
  • 做绿植o2o网站怎么样建设学校网站需要具备
  • 做分享衣服网站的初衷是什么网站架构包括哪些
  • 做网站建设公司企业长沙精品网站建设公司
  • 平价建网站适合乡镇的小型加工厂
  • 网站嵌入地图WordPress去掉新闻
  • 火山开发软件可以开发网站吗wordpress官方
  • 广州市城乡和建设局网站蓝色网站源码
  • 单页展示网站北京品牌建设网站
  • 河南网站建设哪家公司好贵州网站公司
  • 在Edge、Chrome浏览器上安装uBlock Origin插件
  • 合肥专业网站制作设计广西最新一批违法领导
  • 湖南建设厅官方网站官网宁波做网站优化哪家好
  • 做谱的网站企业建设网站流程图
  • php网站开发模式有哪些做本地的门户网站
  • 大语言模型与人类、程序的核心区别