PageHelper 踩坑:不安全分页

结论先行

主要原因:PageHelper使用了静态的ThreadLocal参数,让线程绑定了分页参数, 这个参数如果没被使用就会一直留在那儿,当这个线程再次被使用时,就可能导致不该分页的方法去消费这个分页参数,这就产生了莫名其妙的分页。
在这里插入图片描述
照成原因:

PageHelper.setPage(1,10);
if(param!=null){
	list=userMapper.selectIf(param)
}eles{
	list=new ArrayList<User>();
}
//这样子如果param没有消费到,那么接下来如果进去了其他方法使用了select方法就会将这个page参数带进去,被消费;
改进:

if(param!=null){
	PageHelper.setPage(1,10);
	list=userMapper.selectIf(param)
}eles{
	list=new ArrayList<User>();
}

避坑:让这个分页参数紧跟查询,可以查就建立;也就是保证被消费;或者在finally调用 PageHelper.clearPage();清除

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值