问题:PageHelper自动添加limit
使用
1)、统计总数,(将SQL语句变为 select count(0) from xxx,只对简单SQL语句其效果,复杂SQL语句需要自己写) Page<?> page = PageHelper.startPage(1,-1); long count = page.getTotal(); 2)、分页,pageNum - 第N页, pageSize - 每页M条数 A、只分页不统计(每次只执行分页语句) PageHelper.startPage([pageNum],[pageSize]); List<?> pagelist = queryForList( xxx.class, "queryAll" , param); //pagelist就是分页之后的结果 B、分页并统计(每次执行2条语句,一条select count语句,一条分页语句)适用于查询分页时数据发生变动,需要将实时的变动信息反映到分页结果上 Page<?> page = PageHelper.startPage([pageNum],[pageSize],[iscount]); List<?> pagelist = queryForList( xxx.class , "queryAll" , param); long count = page.getTotal(); //也可以 List<?> pagelist = page.getList(); 获取分页后的结果集 3)、使用PageHelper查全部(不分页) PageHelper.startPage(1,0); List<?> alllist = queryForList( xxx.class , "queryAll" , param); 4)、PageHelper的其他API String orderBy = PageHelper.getOrderBy(); //获取orderBy语句 Page<?> page = PageHelper.startPage(Object params); Page<?> page = PageHelper.startPage(int pageNum, int pageSize); Page<?> page = PageHelper.startPage(int pageNum, int pageSize, boolean isCount); Page<?> page = PageHelper.startPage(pageNum, pageSize, orderBy); Page<?> page = PageHelper.startPage(pageNum, pageSize, isCount, isReasonable); //isReasonable分页合理化,null时用默认配置 Page<?> page = PageHelper.startPage(pageNum, pageSize, isCount, isReasonable, isPageSizeZero); //isPageSizeZero是否支持PageSize为0,true且pageSize=0时返回全部结果,false时分页,null时用默认配置
什么时候会导致不安全的分页?
PageHelper 方法使用了静态的 ThreadLocal 参数,分页参数和线程是绑定的。
只要你可以保证在 PageHelper 方法调用后紧跟 MyBatis 查询方法,这就是安全的。因为 PageHelper 在 finally 代码段中自动清除了 ThreadLocal 存储的对象。
如果代码在进入 Executor 前发生异常,就会导致线程不可用,这属于人为的 Bug(例如接口方法和 XML 中的不匹配,导致找不到 MappedStatement 时), 这种情况由于线程不可用,也不会导致 ThreadLocal 参数被错误的使用。
但是如果你写出下面这样的代码,就是不安全的用法:
PageHelper.startPage(1, 10); List<Country> list; if(param1 != null){ list = countryMapper.selectIf(param1); } else { list = new ArrayList<Country>(); }
这种情况下由于 param1 存在 null 的情况,就会导致 PageHelper 生产了一个分页参数,但是没有被消费,这个参数就会一直保留在这个线程上。当这个线程再次被使用时,就可能导致不该分页的方法去消费这个分页参数,这就产生了莫名其妙的分页。
上面这个代码,应该写成下面这个样子:
List<Country> list; if(param1 != null){ PageHelper.startPage(1, 10); list = countryMapper.selectIf(param1); } else { list = new ArrayList<Country>(); }
这种写法就能保证安全。
如果你对此不放心,你可以手动清理 ThreadLocal 存储的分页参数,可以像下面这样使用:
List<Country> list; if(param1 != null){ PageHelper.startPage(1, 10); try{ list = countryMapper.selectAll(); } finally { PageHelper.clearPage(); } } else { list = new ArrayList<Country>(); }
这么写很不好看,而且没有必要。
转载:https://blog.csdn.net/Trista_1999/article/details/95321354
带着疑问去思考,然后串联,进而归纳总结,不断追问自己,进行自我辩证,像侦查嫌疑案件一样看待技术问题,漆黑的街道,你我一起寻找线索,你就是技术界大侦探福尔摩斯