1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        PageHelper分頁(yè)規(guī)則

        共 11019字,需瀏覽 23分鐘

         ·

        2021-05-09 20:02

        來(lái)源:blog.csdn.net/qq_35080796/article/details/105508744

        1.問(wèn)題

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

        1.1.PageHelper先開(kāi)啟分頁(yè),后對(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;
            }

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

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

        @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ù)可以查詢(xún)出來(lái),總數(shù)total也正確,但是分頁(yè)功能失效。(搜索公眾號(hào)Java知音,回復(fù)“2021”,送你一份Java面試題寶典)

        2.原因

        PageHelper中startPage開(kāi)啟分頁(yè)方法只對(duì)后面的sql查詢(xún)起作用

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

        /**
        * 包裝Page對(duì)象
        *
        @param list
        */

        public PageInfo(List list) {
        this(list, 8);
        }

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

        1.2 錯(cuò)誤原因是先對(duì)list操作后,開(kāi)啟翻頁(yè)后沒(méi)有sql語(yǔ)句

        即sql語(yǔ)句沒(méi)有參與分頁(yè)查詢(xún)

        3.解決方案

        直接對(duì)分頁(yè)后的PageInfo對(duì)象中的數(shù)據(jù)進(jìn)行操作

        • 對(duì)list集合操作,先取出PageInfo里的list集合數(shù)據(jù),再對(duì)數(shù)據(jù)進(jìn)行相關(guān)操作
        • 將操作完后的list集合再次存到PageInfo里,進(jìn)行return
        @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ù)制分頁(yè)屬性
                BeanUtils.copyProperties(source, target);
                // 對(duì)查詢(xún)的list進(jìn)行下一步操作,比如類(lèi)型轉(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ù)放入新的pageinfo
                target.setList(hdQueryVos);

                return target;
            }

        參考資料:

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


        瀏覽 46
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        評(píng)論
        圖片
        表情
        推薦
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            北条麻妃av在线播放 | 国产黄色小说在线观看 | 高潮久久久久久 | 国产丝袜乱伦 | 成人丁香五月 | 我与子的性过程 | 女人18片毛片120分钟 | 国产色婷婷视频在线观看 | 床叫不停娇撞击娇吟np | 大香焦手机免费视频 |