Spring 聚合查询

目前在spring data jpa查询还没有支持聚合查询,工作中需要得使用原生查询。

@Repository 接口查询

@Query(value = “select send_to_test_by as developerId,type,sum(spend_time_with_plan) as plantime,
sum(spend_time_with_develop) as developtime,sum(bugqty) as bugqty from b_task where release_id = ?1
group by type,send_to_test_by”, nativeQuery = true)
List<Object[]> getReleaseDeveloerReport(Long release_id);
查询结果不能是其它对象,只能是List<Object[]>

调用

@Override
public List getDeveloperTimeByRelease(Release release) {
List result = new ArrayList<>();
List<Object[]> list = taskRepository.getReleaseDeveloerReport(release.getId());
for (Object[] obj : list) {
ReleaseDeveloerReport rdr = new ReleaseDeveloerReport();
if (!ObjectUtils.isEmpty(obj[0])) {
rdr.setDeveloperId(NumberUtils.toLong(obj[0].toString()));
rdr.setDeveloper(userRepository.findOne(rdr.getDeveloperId()).getUsername());
rdr.setProgress(getTaskProgress(release, rdr.getDeveloperId(), rdr.getType()));
}
rdr.setType(obj[1].toString());
rdr.setPlantime(obj[2].toString());
rdr.setDeveloptime(obj[3].toString());
if (!ObjectUtils.isEmpty(obj[4])) {
rdr.setBugqty(NumberUtils.toInt(obj[4].toString()));
}
result.add(rdr);
}
return result;
}
调用这块其实也不复杂,关键是要处理好数组。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值