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

旅游网站设计与制作课程设计珠宝 东莞网站建设

旅游网站设计与制作课程设计,珠宝 东莞网站建设,wordpress缓存机制,订阅号可以做微网站一、引言 分页查询是Web开发的必备功能,MyBatis生态中的PageHelper以其简单易用的特性广受欢迎。本文将从源码层面(v5.3.2)解析PageHelper的分页实现机制,结合MySQL方言展示完整的执行链路。 二、核心实现原理 1. 插件初始化 …

一、引言

分页查询是Web开发的必备功能,MyBatis生态中的PageHelper以其简单易用的特性广受欢迎。本文将从源码层面(v5.3.2)解析PageHelper的分页实现机制,结合MySQL方言展示完整的执行链路。

二、核心实现原理

1. 插件初始化

PageHelper通过MyBatis插件机制注册拦截器

2. 分页参数设置

PageHelper.startPage()方法触发分页:

public static <E> Page<E> startPage(int pageNum, int pageSize) {return startPage(pageNum, pageSize, DEFAULT_COUNT);
}// 本质是通过ThreadLocal存储分页参数
public static <E> Page<E> startPage(int pageNum, int pageSize, boolean count) {Page<E> page = new Page<>(pageNum, pageSize, count);setLocalPage(page); // ThreadLocal保存return page;
}

3. SQL拦截过程

核心拦截逻辑(关键代码精简):

public Object intercept(Invocation invocation) throws Throwable {// 1. 获取分页参数Page page = getLocalPage();// 2. 生成COUNT查询SQLif (page.isCount()) {count(page, mappedStatement, parameterObject, boundSql);}// 3. 生成分页SQL(MySQL方言)String pageSql = dialect.getPageSql(originalSql, page, page.getPageSizeKey());// 4. 反射修改BoundSql中的SQLField sqlField = boundSql.getClass().getDeclaredField("sql");sqlField.setAccessible(true);sqlField.set(boundSql, pageSql);// 5. 执行修改后的SQLreturn invocation.proceed();
}

4. MySQL方言处理

MySqlDialect生成LIMIT子句:

public class MySqlDialect extends AbstractHelperDialect {public String getPageSql(String sql, Page page, String orderBy) {StringBuilder sqlBuilder = new StringBuilder(sql.length() + 20);sqlBuilder.append(sql);sqlBuilder.append(" LIMIT ?, ?");return sqlBuilder.toString();}// 参数处理逻辑public Object processPageParameter(...){paramMap.put("pageNum", page.getStartRow());paramMap.put("pageSize", page.getPageSize());}
}

三、执行流程详解(以pageNum=2, pageSize=10为例)

  1. 参数设置阶段

    • startPage(2, 10)创建Page对象并存入ThreadLocal
    • Page对象计算偏移量:offset = (2-1)*10 = 10
  2. SQL拦截阶段

    • 原始SQL:SELECT * FROM user
    • 改写后SQL:SELECT * FROM user LIMIT 10, 10
  3. 参数绑定阶段

    • 设置PreparedStatement参数:
      pstmt.setInt(1, 10); // offset
      pstmt.setInt(2, 10); // pageSize
  4. 结果封装阶段

    // Page继承ArrayList
    Page<User> pageResult = (Page<User>) resultList;
    pageResult.setTotal(100); // 总记录数
  5. PageInfo构建

    new PageInfo<>(pageResult).getTotalPages(); // 计算总页数=10

四、关键设计亮点

  1. ThreadLocal线程隔离

    protected static final ThreadLocal<Page> LOCAL_PAGE = new ThreadLocal<>();
  2. 自动方言识别

    <!-- 根据jdbcUrl自动识别 -->
    <property name="helperDialect" value="mysql"/>
  3. 智能COUNT优化

    SELECT COUNT(0) FROM (原查询SQL) tmp_count

五、最佳实践建议

  1. 避免深分页

    -- 页码过大时建议改用游标分页
    SELECT * FROM user WHERE id > #{lastId} LIMIT 10
  2. 参数校验配置

    PageHelper.startPage(0, 10); // 自动修正为pageNum=1
  3. 特殊查询处理

    PageHelper.startPage(1, 10).disableCount(); // 不执行COUNT查询

六、总结

PageHelper通过MyBatis插件机制实现物理分页,其核心在于:

  1. ThreadLocal存储分页上下文
  2. 动态改写SQL语句
  3. 多方言支持体系
  4. 自动COUNT查询优化

结合MySQL的LIMIT语法特性,PageHelper在保证性能的同时提供了简洁的开发体验。理解其实现原理有助于避免深分页等常见问题,更好地发挥分页功能的价值。

http://www.dtcms.com/wzjs/831694.html

相关文章:

  • 怎么样免费建设网站海南台风最新消息今天
  • 用jsp做婚纱网站的流程网络管理系统平台有哪些
  • 网站开发职业前景logo制作软件免费版
  • 主题资源网站制作平台原画零基础自学
  • 好的网页网站设计seo常见的优化技术
  • 云南百度智能建站中国数据网
  • 网站如何做快照wordpress访问私密帖子
  • app制作和网站一样吗北京怎么进行网页设计
  • 郑州网站推广哪家专业在线视频网站开发成本
  • 广东省建设安全中心网站做学术用的网站
  • 上海缘魁网站建设外贸型网站制作
  • 网站优化细节wordpress图片并列排
  • 网站建站如何做seo做旅游网站怎么融资
  • 网站建设是管理费用的哪项费用网页免费建站
  • 嘿客免费网站建设做便宜的宝贝的网站
  • 做汽车配件招聘网站网站系统分类
  • 无锡网站建设书生商友企业设计公司
  • 制作网站推广码怎样开平台软件
  • 建立网站 用英语网站开发做什么科目
  • 如何让客户做网站网站采集到wordpress
  • .net微信网站开发公司域名让做网站的
  • 网站设计模板素材wordpress图片太大
  • 做电影网站赚钱吗wordpress后台菜单管理
  • 海南第六建设工程有限公司网站织梦网站被黑
  • 摄影作品网站或app软件工程开发师
  • 营销式网站有些网站做不了seo
  • 爱站关键词挖掘软件深圳公司网站制作
  • 河南宏业建设管理有限公司网站asp网站防注入代码
  • c 做的网站怎么上传图片网站建设免费加盟代理
  • 网页设计与网站建设教材专门做实习计算机项目的网站平台