色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

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

阿里巴巴Java開發(fā)手冊(cè)

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

1.1.PageHelper先開啟分頁,后對(duì)list數(shù)據(jù)操作

@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; }

可以分頁,但是數(shù)據(jù)量錯(cuò)誤,total始終等于每頁數(shù)據(jù)量,即pageSize

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

1.2.先對(duì)list數(shù)據(jù)進(jìn)行操作,后開啟分頁

@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; }

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

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

2.原因

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

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

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

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

只是把list轉(zhuǎn)為PageInfo對(duì)象,不影響前面分頁數(shù)據(jù)的操作

1.2 錯(cuò)誤原因是先對(duì)list操作后,開啟翻頁后沒有sql語句

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

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

3.解決方案

直接對(duì)分頁后的PageInfo對(duì)象中的數(shù)據(jù)進(jìn)行操作①對(duì)list集合操作,先取出PageInfo里的list集合數(shù)據(jù),再對(duì)數(shù)據(jù)進(jìn)行相關(guān)操作②將操作完后的list集合再次存到PageInfo里,進(jìn)行return

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

@Override public PageInfo<HdQueryVo> getRecordsByView(int pageNo, int pageSize) {PageInfo<HdQueryVo> source = PageHelper.startPage(pageNo, pageSize).doSelectPageInfo(()->{ actionMapper.getActionByView();});// 需要轉(zhuǎn)換的對(duì)象PageInfo<HdQueryVo> target = new PageInfo<>();// 復(fù)制分頁屬性BeanUtils.copyProperties(source, target);// 對(duì)查詢的list進(jìn)行下一步操作,比如類型轉(zhuǎn)換后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);}// 加工后的數(shù)據(jù)放入新的pageinfotarget.setList(hdQueryVos);return target; }

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效

參考資料:

PageHelper官方文檔PageHelper分頁查詢結(jié)果后再對(duì)數(shù)據(jù)List操作的方法

到此這篇關(guān)于Java中PageHelper分頁后對(duì)list操作導(dǎo)致分頁無效的文章就介紹到這了,更多相關(guān)Java PageHelper分頁無效內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 欧美黄视频网站 | 三级三级三级全黄 | 中文字幕一区二区三区 精品 | 美女一级毛片 | 三级视频中文字幕 | 亚洲一级毛片欧美一级说乱 | 欧美精品久久天天躁 | 久久免费高清视频 | 在线久久 | 久久综合久久88 | 欧美一级成人 | 国产精品成人免费综合 | 精品久久成人 | 成人a毛片免费视频观看 | 欧美人与z0z0xxxx | 国产精品免费大片一区二区 | 欧美三级不卡在线观看视频 | 一级做a爱过程免费视频麻豆 | 久久国产精品久久久久久久久久 | 亚洲视频1区 | 日韩欧美印度一级毛片 | 欧美视频在线一区二区三区 | 国产亚洲精品看片在线观看 | 成人女人a毛片在线看 | 国产福利片在线 易阳 | 欧美日韩专区国产精品 | 99久久精品免费看国产免费软件 | 天堂在线www网亚洲 天堂在线视频网站 | 久久香蕉国产线看观看亚洲片 | 国产精品久久久久9999小说 | 亚洲第一视频在线观看 | 久久精品亚洲一区二区 | 亚洲国产日韩精品 | 天天欲色成人综合网站 | 欧美成人网7777视频 | 亚洲国产精品ⅴa在线观看 亚洲国产精品aaa一区 | 美女被爆免费视频软件 | 国产做a爰片久久毛片 | 国产三级视频在线 | 欧美日韩一本 | 一级毛片牲交大片 |