ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

SpringBoot使用Mybatis-PageHelper,和PageResult

2019-08-30 21:39:11  阅读:327  来源: 互联网

标签:分页 spu PageHelper spuBos spuBo Mybatis new PageResult spus


public PageResult<SpuBo> querySpuBoByPage(String key, Boolean saleable, Integer page, Integer rows) {

        Example example = new Example(Spu.class);
        Example.Criteria criteria = example.createCriteria();
        // 搜索条件
        if (StringUtils.isNotBlank(key)){
            criteria.andLike("title","%"+key+"%");
        }
        if (!Objects.isNull(saleable)){
            criteria.andEqualTo("saleable",saleable);
        }

        //分页
        PageHelper.startPage(page,rows);   // 分页条件
        /**
         * 分页条件必须放在下面的查询语句前面
         */
        // 执行查询
        List<Spu> spus=this.spuMapper.selectByExample(example);

        PageInfo<Spu> pageInfo = new PageInfo<>(spus);

        //扩展的spuBos  list
        ArrayList<SpuBo> spuBos = new ArrayList<SpuBo>();
        spus.forEach(spu -> {
            SpuBo spuBo = new SpuBo();
            // copy共同属性的值到新的对象
            BeanUtils.copyProperties(spu,spuBo);

            // 查询分类名称
            List<String> names = this.categoryService.queryNamesByIds(Arrays.asList(spu.getCid1(), spu.getCid2(), spu.getCid3()));
            //设置spuBo的cname
            spuBo.setCname(StringUtils.join(names,"/"));
            //设置spuBo的bname
            Brand brand = this.brandMapper.selectByPrimaryKey(spu.getBrandId());
            String bname = brand.getName();
            spuBo.setBname(bname);

            //spuBo属性设置完成  添加到spuBos
            spuBos.add(spuBo);
            spuBo=null;
        });

        return new PageResult<SpuBo>(pageInfo.getTotal(),pageInfo.getPages(),spuBos);
    }

分页结果,可以调整分页
在这里插入图片描述
如果把PageHelper.startPage(page,rows); // 分页条件
放在List<Spu> spus=this.spuMapper.selectByExample(example);之后
结果为查询所有

标签:分页,spu,PageHelper,spuBos,spuBo,Mybatis,new,PageResult,spus
来源: https://blog.csdn.net/illusory_germ/article/details/100165902

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有