PageHelper 分页时,PageNum = 1
问题描述 : 在使用Page Helper插件进行分页使,不论前台提供pageNum,PageSize 是多少,或者不论查询的List的size是多大,返回前端的时候总是PageNum=1,PageSize = list.size()
if (list instanceof Page) {
Page page = (Page)list;
this.pageNum = page.getPageNum();
this.pageSize = page.getPageSize();
this.pages = page.getPages();
this.size = page.size();
if (this.size == 0) {
this.startRow = 0;
this.endRow = 0;
} else {
this.startRow = page.getStartRow() + 1;
this.endRow = this.startRow - 1 + this.size;
}
} else if (list instanceof Collection) {
this.pageNum = 1;
this.pageSize = list.size();
this.pages = this.pageSize > 0 ? 1 : 0;
this.size = list.size();
this.startRow = 0;
this.endRow = list.size() > 0 ? list.size() - 1 : 0;
}
通过调试发现,无论怎么查询,list instanceof Collection 总是为true,这也就说明了,为什么PageNum=1,pageSize=list.size 这个现象了。
list instanceof Collection 至少说明了目前这个 list 是一个普通的list,而不是被PageHelper进行处理过的list
但是为什么这个list没有被处理呢?
查看代码发现我在service中对mapper查询的结果list进行了处理,重新返回了一个新的list,这也许就是这个list instance Collection = true 的原因。
当使用foreach 对结果集进行处理,返回当前查询到的list时,问题迎刃而解!!!
目前这么理解,先记录下来,待以后有了新的发现再更改