物理分页与逻辑分页 物理分页 物理分页依赖的是某一物理实体,这个物理实体就是数据库,比如Mysql数据库提供了limit关键字,程序员只需要编写带有limit关键字的sql语句,数据库返回的就是分页结果。 逻辑分页 逻辑分页依赖的是程序员编
物理分页
物理分页依赖的是某一物理实体,这个物理实体就是数据库,比如Mysql数据库提供了limit关键字,程序员只需要编写带有limit关键字的sql语句,数据库返回的就是分页结果。
逻辑分页
逻辑分页依赖的是程序员编写的代码。数据库返回的不是分页结果,而是全部数据,然后再由程序员通过代码获取分页数据,常用的操作是一次性从数据库中查询出全部数据并存储到List集合中,因为List集合有序,再根据索引获取指定范围的数据。
分页需要计算传入分页的第几页数,查询结果的总条数,总共有多少页,如下代码:
@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
--结束END--
本文标题: 使用java Steam流进行逻辑分页(内存分页)
本文链接: https://lsjlt.com/news/393420.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0