SpringBoot使用Mybatis-PageHelper,和PageResult

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

分页结果,可以调整分页
SpringBoot使用Mybatis-PageHelper,和PageResult
如果把PageHelper.startPage(page,rows); // 分页条件
放在List<Spu> spus=this.spuMapper.selectByExample(example);之后
结果为查询所有

上一篇:回顾C++回调函数


下一篇:SPU、SKU、ARPU