物理分页
物理分页依赖的是某一物理实体,这个物理实体就是数据库,比如MySQL数据库提供了limit关键字,程序员只需要编写带有limit关键字的SQL语句,数据库返回的就是分页结果。
逻辑分页
逻辑分页依赖的是程序员编写的代码。数据库返回的不是分页结果,而是全部数据,然后再由程序员通过代码获取分页数据,常用的操作是一次性从数据库中查询出全部数据并存储到List集合中,因为List集合有序,再根据索引获取指定范围的数据。
使用 java Steam流进行逻辑分页分页需要计算传入分页的第几页数,查询结果的总条数,总共有多少页,如下代码:
@Service
public class UserServiceImpl implements UserService {
@Override
public ResponsePage userPage(Integer page, Integer size) {
//查出user总数量
ListuserList=userReposity.findAll();
//使用Stream流分页 sorted()排序,skip()跳过多少数据,limit()限制取多少条记录
ListpageResult = 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);
}
}
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
名称栏目:使用javaSteam流进行逻辑分页(内存分页)-创新互联
当前地址:https://www.cdcxhl.com/article16/ipogg.html
成都网站建设公司_创新互联,为您提供网站设计公司、企业建站、响应式网站、网页设计公司、静态网站、手机网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联