大数据最全若依框架---PageHelper分页(十)_若依如何取消分页限制,2024年最新分享复习经验和后台开发面经

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

if (!dialect.beforePage(ms, parameter, rowBounds)) {
return executor.query(ms, parameter, RowBounds.DEFAULT, resultHandler, cacheKey, boundSql);
} else {
parameter = dialect.processParameterObject(ms, parameter, boundSql, cacheKey);
String pageSql = dialect.getPageSql(ms, boundSql, parameter, rowBounds, cacheKey);
// 其他代码 …
}


今天应该阅读`dialect.getPageSql`方法了。通过前面的文章,我们已经知道dialect对应的实现是MysqlDialect,那么getPageSql在MySql中的具体实现是什么样的呢?



public class MySqlDialect extends AbstractHelperDialect {
public String getPageSql(String sql, Page page, CacheKey pageKey) {
StringBuilder sqlBuilder = new StringBuilder(sql.length() + 14);
sqlBuilder.append(sql);
if (page.getStartRow() == 0L) {
sqlBuilder.append("\n LIMIT ? “);
} else {
sqlBuilder.append(”\n LIMIT ?, ? ");
}

    return sqlBuilder.toString();
}

}


经过不懈的查找,我们终于看到了对SQL语句的直接修改了。(*^▽^*)。


这里的写法也很值得学习,首先是使用StringBuilder加速字符串拼接速度;其次,是在拼接前首先开辟充足的空间`new StringBulder(sql.length() + 14)`以免在StringBuilder拼接过程中再次分配空间浪费时间。


然后我们就看到了SQL拼接啦!!!


首先判断是否是第一页,如果是第一页,则拼接`\n LIMIT ?`,不是第一页则拼接`\n LIMIT ?, ?`。


至此我们终于看到了SQL修改的真容。


为表庆祝,已经确定我们查看的就是代码执行位置,今天我们换种形式,借助IDEA来逐步查看Java代码的执行情况。


以若依系统中的中某个页面,如“系统监控->定时任务”存在分页,我们以此为例。


页面加载完成后是下面的样子:


![](https://img-blog.csdnimg.cn/865ede3ef5684a39b0046e6211846a69.png)


 我们首先在PageInterceptor拦截器入口处打一个断点。:


![](https://img-blog.csdnimg.cn/c632c535a2ff41be8886b47828809c1b.png)



并成功拦截。


然后我们在MysqlDialect修改方法出打一个断点,并再次成功拦截!开心!


![](https://img-blog.csdnimg.cn/6ce2471bb01643b389a57870429de78a.png)





![img](https://img-blog.csdnimg.cn/img_convert/e95f041ee26cedbd09b0a44c60ed4524.png)
![img](https://img-blog.csdnimg.cn/img_convert/5c9800b346ae1b9437e393918793e7a5.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.youkuaiyun.com/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值