SpringBoot使用Mybatis-PageHelper,和PageResult

public PageResult 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 spus=this.spuMapper.selectByExample(example);

        PageInfo pageInfo = new PageInfo<>(spus);

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

            // 查询分类名称
            List 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(pageInfo.getTotal(),pageInfo.getPages(),spuBos);
    }

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

关于MyBatis通用Mapper的使用可以看这篇文章

https://blog.csdn.net/illusory_germ/article/details/100145907

你可能感兴趣的:(SpringCloud)