使用java Steam流进行逻辑分页(内存分页)
短信预约 -IT技能 免费直播动态提醒
物理分页与逻辑分页
物理分页
物理分页依赖的是某一物理实体,这个物理实体就是数据库,比如MySQL数据库提供了limit关键字,程序员只需要编写带有limit关键字的SQL语句,数据库返回的就是分页结果。
逻辑分页
逻辑分页依赖的是程序员编写的代码。数据库返回的不是分页结果,而是全部数据,然后再由程序员通过代码获取分页数据,常用的操作是一次性从数据库中查询出全部数据并存储到List集合中,因为List集合有序,再根据索引获取指定范围的数据。
使用 java Steam流进行逻辑分页
分页需要计算传入分页的第几页数,查询结果的总条数,总共有多少页,如下代码:
@Servicepublic class UserServiceImpl implements UserService { @Override public ResponsePage userPage(Integer page, Integer size) { //查出user总数量 List userList=userReposity.findAll(); //使用Stream流分页 sorted()排序,skip()跳过多少数据,limit()限制取多少条记录 List pageResult = userList.stream() .sorted(Comparator.comparing(User::getBrith).reversed()) .skip((page - 1L) * size).limit(size).collect(Collectors.toList()); //记录总条数 int nums = userList.size(); //计算总共有多少页数 int totalPage = (nums % size) > 0 ? nums / size + 1 : nums / size; return new ResponsePage(pageResult,nums,totalPage,size); }}
来源地址:https://blog.csdn.net/m0_37876057/article/details/128190052
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341