BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();
RangeQueryBuilder createTimeQuery = QueryBuilders.rangeQuery("createTime");
createTimeQuery.gte(startTime);
createTimeQuery.lte(endTime);
queryBuilder.must(createTimeQuery);
//过滤面授班
String skuPropertyId = commodityGoodsSupport.getTrainingTypePropertyIdByGoodsCategory(context);
String offLineValue = commodityGoodsSupport.getTrainingTypeOfflineClassPropertyValue(context, "");
String onLineValue = commodityGoodsSupport.getTrainingTypeOnlineClassPropertyValue(context, "");
if (CollectionUtils.isNotEmpty(searchDto.getSkuPropertyList())) {
if (searchDto.isQueryOffLineClass() && StringUtils.isNotBlank(offLineValue)) {
for (SkuPropertyKeyValue item : searchDto.getSkuPropertyList()) {
if (item.getPropertyId().equals(skuPropertyId)) {
item.setValue(offLineValue);
}
}
} else if (!searchDto.isQueryOffLineClass() && StringUtils.isNotBlank(onLineValue)) {
for (SkuPropertyKeyValue item : searchDto.getSkuPropertyList()) {
if (item.getPropertyId().equals(skuPropertyId)) {
item.setValue(onLineValue);
}
}
}
BoolQueryBuilder nestedBoolQuery;
for (SkuPropertyKeyValue item : searchDto.getSkuPropertyList()) {
if (StringUtils.isNotBlank(item.getPropertyId()) && StringUtils.isNotBlank(item.getValue())) {
nestedBoolQuery = QueryBuilders.boolQuery();
nestedBoolQuery.filter(QueryBuilders.termQuery("skuProperties.id", item.getPropertyId()));
nestedBoolQuery.filter(QueryBuilders.termQuery("skuProperties.value", item.getValue()));
queryBuilder.filter(QueryBuilders.nestedQuery("skuProperties", nestedBoolQuery, ScoreMode.None));
}
}
}
queryBuilder.filter(QueryBuilders.termQuery("projectId", context.getProjectId()));
queryBuilder.filter(QueryBuilders.termQuery("subProjectId", context.getSubProjectId()));
// 培训班id
if (StringUtils.isNotBlank(searchDto.getTrainClassId())) {
QueryBuilder trainClassQuery = QueryBuilders.termQuery("trainClassId", searchDto.getTrainClassId());
queryBuilder.must(trainClassQuery);
}
//地区,
if(StringUtils.isNotBlank(searchDto.getRegionPath()) && searchDto.getRegionPath().split("/").length>3){
QueryBuilder trainClassQuery = QueryBuilders.termQuery("unitRegion.countryId", searchDto.getRegionPath().split("/")[3]);
queryBuilder.must(trainClassQuery);
}
SumAggregationBuilder swapInCountMetrics = AggregationBuilders.sum("swapInCountMetrics").field("swapInCount");
SumAggregationBuilder openCountMetrics = AggregationBuilders.sum("openCountMetrics").field("openCount");
SumAggregationBuilder swapOutCountMetrics = AggregationBuilders.sum("swapOutCountMetrics")
.field("swapOutCount");
SumAggregationBuilder refundCountMetrics = AggregationBuilders.sum("refundCountMetrics").field("refundCount");
AggregationBuilder aggregation = AggregationBuilders.terms("trainingGroup").field("unitRegion.countryId")
.subAggregation(swapInCountMetrics).subAggregation(openCountMetrics).subAggregation(swapOutCountMetrics)
.subAggregation(refundCountMetrics);
SearchResponse sr = client.prepareSearch().setIndices(super.entityInformation.getIndexName())
.setTypes(super.entityInformation.getType()).setQuery(queryBuilder)// 过滤条件
.addAggregation(aggregation)// 聚合
.execute().actionGet();
Terms trainingGroup = sr.getAggregations().get("trainingGroup");// 可以统计当前匹配的聚合结果集
return trainingGroup; #获取查询结果
Terms trainingGroup = getBucketAreaInfo(context, searchDto, startTime, endTime);//获取班级聚合的数据
List<Bucket> bucketList = trainingGroup.getBuckets(); for (Bucket b : bucketList) {
PureOpenBucketDto dto = new PureOpenBucketDto();
dto.setCountryId(b.getKeyAsString());
Aggregations aggs = b.getAggregations();
Sum swapInSum = aggs.get("swapInCountMetrics");
Sum swapOutSum = aggs.get("swapOutCountMetrics");
Sum openSum = aggs.get("openCountMetrics");
Sum refundSum = aggs.get("refundCountMetrics"); dto.setSwapInCount(((Double) swapInSum.getValue()).intValue());
dto.setSwapOutCount(((Double) swapOutSum.getValue()).intValue());
dto.setOpenCount(((Double) openSum.getValue()).intValue());
dto.setRefundCount(((Double) refundSum.getValue()).intValue());
dtoList.add(dto);
}
return dtoList;

Elasticsearch **代码片段的更多相关文章

  1. elasticsearch代码片段,及工具类SearchEsUtil.java

    ElasticSearchClient.java package com.zbiti.framework.elasticsearch.utils; import java.util.Arrays; i ...

  2. sublimetext3中保存代码片段

    在日常的开发工作中,不断重复上一次敲过的代码,有时确实感到伐木累."蓝瘦"(难受)."香菇"(想哭),大概表达的也是这样的心境吧!:grinning: 所以,在 ...

  3. Code Snippets 代码片段

    Code Snippets 代码片段       1.Title : 代码片段的标题 2.Summary : 代码片段的描述文字 3.Platform : 可以使用代码片段的平台,有IOS/OS X/ ...

  4. 10个 jQuery 代码片段,可以帮你快速开发。

    转载自:http://mp.weixin.qq.com/s/mMstI10vqwu8PvUwlLborw 1.返回顶部按钮 你可以利用 animate 和 scrollTop 来实现返回顶部的动画,而 ...

  5. 代码片段添加智能提示,打造一款人见人爱的ORM框架

    SqlSugar ORM优点: 1.高性能,达到原生最高水准,比SqlHelper性能要高,比Dapper快30% 比EF快50% 2.支持多种数据库 ,sql版本更新最快,其它会定期更新,可以在多种 ...

  6. js/jquery/html前端开发常用到代码片段

    1.IE条件注释 条件注释简介 IE中的条件注释(Conditional comments)对IE的版本和IE非IE有优秀的区分能力,是WEB设计中常用的hack方法.条件注释只能用于IE5以上,IE ...

  7. Visual Studio 如何使用代码片段Code Snippet提高编程速度!!!

      使用Code Snippet简化Coding 在开发的项目的时候,你是否经常遇到需要重复编写一些类似的代码,比如是否经常会使用 for.foreach ? 在编写这两个循环语句的时候,你是一个字符 ...

  8. Visual Studio 的代码片段工具

    当安装完Visual Studio之后,会有附带一些原生的代码片段文件(*.snippet),对于vs2013参考目录如下: X:\Program Files (x86)\Microsoft Visu ...

  9. sublime代码片段

    创建方法:Tools > New Snippet 这时你会看到如下示例代码: <snippet>      <content><![CDATA[ Hello, ${ ...

随机推荐

  1. golang结构体、接口、反射

    struct结构体 struct用来自定义复杂数据结构,可以包含多个字段属性,可以嵌套; go中的struct类型理解为类,可以定义方法,和函数定义有些许区别; struct类型是值类型. struc ...

  2. 公网定制化yum仓库部署

    公网定制化yum仓库部署 (1)搭建公网源yum仓库 安装wget aliyun源 # wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun ...

  3. jQuery-2.DOM---创建节点及节点属性

    DOM创建节点及节点属性 通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作.但实际上一般开发者都习惯性的先定义好HTML结构,但这样就非常不灵活了. 试想下这样的情况:如 ...

  4. RabbitMq入门以及使用教程

    祭出原帖:https://blog.csdn.net/lyhkmm/article/details/78772919 原文转载:http://blog.csdn.net/whycold/article ...

  5. Semantic Compositionality through Recursive Matrix-Vector Spaces-paper

    Semantic Compositionality through Recursive Matrix-Vector Spaces 作者信息:Richard Socher Brody Huval Chr ...

  6. 软件工程 week 05

    关于 石墨文档客户端 的案例分析 作业地址:https://edu.cnblogs.com/campus/nenu/2016CS/homework/2505 一.调研测评 测试平台:Windows 1 ...

  7. 关于windows下的文件结束符

    在<c++ primer>中有说,在windows中文件结束符为:ctrl+z,在Linux中为:ctrl+D. 但是在while(cin>>s)的语句运行中,需要两次的^Z, ...

  8. linux学习笔记(二:权限)

    Linux下有两种用户: 超级用户(root).普通用户. 超级用户:可以再linux系统下做任何事情,不受限制 普通用户:在linux下做有限的事情,例如:rm -rf 只会删除自己的东西. 超级用 ...

  9. Javascript 香蕉分段吃(数组分隔)

    Javascript 香蕉分段吃(数组分隔) function chunk(arr, size) { var newArr =[]; for(var i = 0; i < arr.length; ...

  10. 3.2 MathType插入竖省略号

    法1:鼠标单击位于上方菜单栏下面的空格和椭圆模版,然后在下拉模版下选择垂直省略号,如下图所示. 按照上面的操作选择垂直省略号模版后,这样在下面的编辑区域就会打出该符号了. 法2:在插入符号下查找 如果 ...