国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Java中PageHelper分頁后對list操作導致分頁無效

瀏覽:23日期:2022-08-11 18:34:25
目錄1.問題1.1.PageHelper先開啟分頁,后對list數據操作1.2.先對list數據進行操作,后開啟分頁2.原因3.解決方案1.問題

阿里巴巴Java開發手冊

Java中PageHelper分頁后對list操作導致分頁無效

1.1.PageHelper先開啟分頁,后對list數據操作

@Override public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {PageHelper.startPage(pageNo,pageSize);List<HdQueryVo> hdQueryVosByView = actionMapper.getActionByView();List<HdQueryVo> hdQueryVos = new ArrayList<>();for (HdQueryVo hdQueryVo : hdQueryVosByView) { HdQueryVo hdQueryVoSingle = new HdQueryVo(); hdQueryVoSingle.setHdId(hdQueryVo.getHdId()); hdQueryVoSingle.setHdType(hdQueryVo.getHdType()); hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle()); hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate()); hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate()); hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus()); hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage()); hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber()); hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate()); hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified()); hdQueryVoSingle.setUserId(hdQueryVo.getUserId()); if (hdQueryVo.getHdType().equals(0)) {hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId())); } else {hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId())); } hdQueryVos.add(hdQueryVoSingle);}PageInfo<HdQueryVo> pageViewInfo = new PageInfo<>(hdQueryVos);return pageViewInfo; }

可以分頁,但是數據量錯誤,total始終等于每頁數據量,即pageSize

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

1.2.先對list數據進行操作,后開啟分頁

@Override public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {List<HdQueryVo> hdQueryVosByView = actionMapper.getActionByView();List<HdQueryVo> hdQueryVos = new ArrayList<>();for (HdQueryVo hdQueryVo : hdQueryVosByView) { HdQueryVo hdQueryVoSingle = new HdQueryVo(); hdQueryVoSingle.setHdId(hdQueryVo.getHdId()); hdQueryVoSingle.setHdType(hdQueryVo.getHdType()); hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle()); hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate()); hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate()); hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus()); hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage()); hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber()); hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate()); hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified()); hdQueryVoSingle.setUserId(hdQueryVo.getUserId()); if (hdQueryVo.getHdType().equals(0)) {hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId())); } else {hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId())); } hdQueryVos.add(hdQueryVoSingle);}PageHelper.startPage(pageNo,pageSize);PageInfo<HdQueryVo> pageViewInfo = new PageInfo<>(hdQueryVos);return pageViewInfo; }

數據可以查詢出來,總數total也正確,但是分頁功能失效

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

2.原因

PageHelper中startPage開啟分頁方法只對后面的sql查詢起作用

1.1 錯誤原因是提前開啟分頁后,對list操作,即PageInfo pageViewInfo = new PageInfo<>(hdQueryVos);

Java中PageHelper分頁后對list操作導致分頁無效

/*** 包裝Page對象** @param list*/public PageInfo(List list) {this(list, 8);}

只是把list轉為PageInfo對象,不影響前面分頁數據的操作

1.2 錯誤原因是先對list操作后,開啟翻頁后沒有sql語句

Java中PageHelper分頁后對list操作導致分頁無效

即sql語句沒有參與分頁查詢

3.解決方案

直接對分頁后的PageInfo對象中的數據進行操作①對list集合操作,先取出PageInfo里的list集合數據,再對數據進行相關操作②將操作完后的list集合再次存到PageInfo里,進行return

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

@Override public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {PageInfo<HdQueryVo> source = PageHelper.startPage(pageNo, pageSize).doSelectPageInfo(()->{ actionMapper.getActionByView();});// 需要轉換的對象PageInfo<HdQueryVo> target = new PageInfo<>();// 復制分頁屬性BeanUtils.copyProperties(source, target);// 對查詢的list進行下一步操作,比如類型轉換后List<HdQueryVo> collect = source.getList().stream().collect(Collectors.toList());List<HdQueryVo> hdQueryVos = new ArrayList<>();for (HdQueryVo hdQueryVo : collect) { HdQueryVo hdQueryVoSingle = new HdQueryVo(); hdQueryVoSingle.setHdId(hdQueryVo.getHdId()); hdQueryVoSingle.setHdType(hdQueryVo.getHdType()); hdQueryVoSingle.setHdTitle(hdQueryVo.getHdTitle()); hdQueryVoSingle.setHdStartDate(hdQueryVo.getHdStartDate()); hdQueryVoSingle.setHdEndDate(hdQueryVo.getHdEndDate()); hdQueryVoSingle.setHdStatus(hdQueryVo.getHdStatus()); hdQueryVoSingle.setHdImage(hdQueryVo.getHdImage()); hdQueryVoSingle.setHdNumber(hdQueryVo.getHdNumber()); hdQueryVoSingle.setGmtCreate(hdQueryVo.getGmtCreate()); hdQueryVoSingle.setGmtModified(hdQueryVo.getGmtModified()); hdQueryVoSingle.setUserId(hdQueryVo.getUserId()); if (hdQueryVo.getHdType().equals(0)) {hdQueryVoSingle.setHdJoinUsers(onlineWorksMapper.getOnlineJoinUsers(hdQueryVo.getHdId())); } else {hdQueryVoSingle.setHdJoinUsers(offlineUsersMapper.getOfflineJoinUsers(hdQueryVo.getHdId())); } hdQueryVos.add(hdQueryVoSingle);}// 加工后的數據放入新的pageinfotarget.setList(hdQueryVos);return target; }

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

Java中PageHelper分頁后對list操作導致分頁無效

參考資料:

PageHelper官方文檔PageHelper分頁查詢結果后再對數據List操作的方法

到此這篇關于Java中PageHelper分頁后對list操作導致分頁無效的文章就介紹到這了,更多相關Java PageHelper分頁無效內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产亚洲精品美女一区二区 | 日本高清毛片视频在线看 | 性生大片一级毛片免费观看 | yy毛片| 日日碰碰 | 亚洲成人一级 | 日本三级在线观看中文字 | 国产精品热久久毛片 | 精品国产v无码大片在线观看 | 男女很舒服爽视频免费 | 99秒拍福利大尺度视频 | 国产成人毛片精品不卡在线 | 真正全免费视频a毛片 | 亚洲一区www | 最新国产美女肝交视频播放 | 国产91精品一区 | 亚洲久久在线观看 | 在线观看中文字幕国产 | 91伊人影院 | 大量愉拍情侣在线视频 | 在线免费看一级片 | 国产深夜福利视频在线播放 | 91理论片午午伦夜理片久久 | 国产成人综合手机在线播放 | 国产成人一区二区三区在线播放 | 国产呦系列免费 | 在线国产毛片 | 91碰碰 | 国产欧美另类久久久精品免费 | 视频一区二区三区在线 | 久久亚洲成a人片 | 国产成人精品一区二区秒拍 | 免费男女乱淫真视频播放 | www.日本在线 | 亚洲欧美日韩国产精品影院 | 99久久一区 | 亚洲人成网站色7799在线观看 | 日韩乱码中文字幕视频 | 日韩一级片免费在线观看 | 中文字幕 亚洲 一区二区三区 | 欧美成人网7777视频 |