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. 剑指Offer 49. 把字符串转换成整数 (字符串)

    题目描述 将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一 ...

  2. jQuery ajax瀑布流加载静态的列表页面

    1.加载一行数据 <script> //滚动加载事件 var Loadurl = "{$url}"; if(window.location.href !== Loadu ...

  3. mission 01

    A.自己目前在专业能力上的短板,及打算如何弥补. answer:由于在课本中所学的知识是死板的,加上不知如何课外提高自己在专业上的实践应用能力,所以我认为我在专业能力上的短板是缺乏将所掌握的知识应用到 ...

  4. hive数据导出到本地目录 抛异常

    经过反复试验,最终重启hdfs和hive解决问题 hive> insert overwrite local directory '/Users/wooluwalker/Desktop/' sel ...

  5. ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开ORACLE企业管理器(EM)的解决办法

    环境:win7 64位系统. 软件:oracle11g database ,oracle 10g client . 问题描述:在win7 64位系统下安装oracle11g,在创建数据库时,进度到85 ...

  6. 初学版本控制更新Version control

    概述: 在学习计算机软件工程中,修订控制是跟踪和控制源代码更改的任何类型的实践. 对于软件开发人员有时会使用修订控制软件来维护文档和配置文件以及源代码. 当团队设计,开发和部署软件时,通常会将同一软件 ...

  7. Yii2事件驱动的运行机制

    最近一段时间正在作个一个项目,这个项目会系统逻辑比较复杂,使用PHP Yii2,使用事件驱动机制进行研发,下面就最近研究事件驱动机制的使用作以下总结: 流程如下: 1.要创建含有事件注入的类,一般这样 ...

  8. 查询正在运行的请求及其后台对应SQL

    SELECT a.event , s.actual_start_date , a.sid, a.serial#, sa.sql_fulltext , sa.sql_text , v.user_conc ...

  9. PythonStudy——PyCharm 选择性忽略PEP8代码风格警告信息

    用了几天的PyCharm,发现确实在编写Python代码上非常好用,但有一点体验不太好,就是代码编写时要按照PEP8代码风格编写,不然会有波浪线的警告信息.解决方法如下: 方法一:将鼠标移到提示的地方 ...

  10. Fabric实例

    Fabric的官网  http://fabric-chs.readthedocs.io/zh_CN/chs/index.html 参考<Python自动化运维 技术与最佳实践>   1:查 ...