mybatisplus group by 归组

52 篇文章 0 订阅
 QueryWrapper<MetaItem> wrapper = new QueryWrapper<MetaItem>()
                .select("set_id,count(0) as field_count")
                .in("set_id",setids)
                .groupBy("set_id");

        List<Map<String,Object>> list = itemService.listMaps(wrapper);

注意要用 listMaps ,返回的是 Map<String,Object>

示例:

public Result<?> queryPageList(MetaSet metaSet,
								   @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
								   @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
								   HttpServletRequest req) {
		QueryWrapper<MetaSet> queryWrapper = QueryGenerator.initQueryWrapper(metaSet, req.getParameterMap());
		Page<MetaSet> page = new Page<MetaSet>(pageNo, pageSize);
		IPage<MetaSet> pageList = metaSetService.page(page, queryWrapper);

        List<MetaSet> records = pageList.getRecords();
        List<String> setids = records.stream().map(f -> f.getId()).collect(Collectors.toList());

        QueryWrapper<MetaItem> wrapper = new QueryWrapper<MetaItem>()
                .select("set_id,count(0) as field_count")
                .in("set_id",setids)
                .groupBy("set_id");

        List<Map<String,Object>> list = itemService.listMaps(wrapper);

        records.forEach(f->{
            Map<String, Object> set_id = list.stream().filter(l -> l.get("set_id").toString().equals(f.getId())).findFirst().orElse(null);
            if(set_id!=null){
                f.setFieldCount(Integer.valueOf(set_id.get("field_count").toString()));
            }
        });
        pageList.setRecords(records);

        return Result.OK(pageList);
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值