elasticsearch(八)调用TransportClient统计查询结果处理

聚合查询后,使用不同的聚合获取值的方式也不相同。

针对上篇第一查询处理

//聚合处理
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
// 总和, 平均值, 最大值,最小值
AbstractAggregationBuilder valueCountAggregationBuilder = AggregationBuilders.count("count").field("name");
AbstractAggregationBuilder sumAggregationBuilder = AggregationBuilders.sum("sum").field("score");
AbstractAggregationBuilder avgAggregationBuilder = AggregationBuilders.avg("avg").field("score");
AbstractAggregationBuilder maxAggregationBuilder = AggregationBuilders.max("max").field("score");
AbstractAggregationBuilder minAggregationBuilder = AggregationBuilders.min("min").field("score");

		sourceBuilder.aggregation(valueCountAggregationBuilder).aggregation(sumAggregationBuilder).aggregation(avgAggregationBuilder)
	.aggregation(maxAggregationBuilder).aggregation(minAggregationBuilder);

try {
	//查询索引对象
	SearchRequest searchRequest = new SearchRequest(index);
	searchRequest.types(type);
	searchRequest.source(sourceBuilder);
	SearchResponse searchResponse = client.search(searchRequest).get();
	System.out.println(searchResponse);

	InternalValueCount valueCount = searchResponse.getAggregations().get("count");
	System.out.println(valueCount.getValue());

	InternalSum internalSum = searchResponse.getAggregations().get("sum");
	System.out.println(internalSum.getValue());
			
	InternalAvg internalAvg = searchResponse.getAggregations().get("avg");
	System.out.println(internalAvg.getValue());
			
	InternalMin internalMin = searchResponse.getAggregations().get("min");
	System.out.println(internalMin.getValue());
			
	InternalMax internalMax = searchResponse.getAggregations().get("max");
	System.out.println(internalMax.getValue());

} catch (InterruptedException | ExecutionException e) {
	e.printStackTrace();
}

第二和第三 分组查询个查询处理

//聚合处理
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
// 总和, 平均值, 最大值,最小值
AbstractAggregationBuilder sumAggregationBuilder = AggregationBuilders.sum("sum").field("score");
AbstractAggregationBuilder avgAggregationBuilder = AggregationBuilders.avg("avg").field("score");
AbstractAggregationBuilder maxAggregationBuilder = AggregationBuilders.max("max").field("score");
AbstractAggregationBuilder minAggregationBuilder = AggregationBuilders.min("min").field("score");

//		sourceBuilder.aggregation(valueCountAggregationBuilder).aggregation(sumAggregationBuilder).aggregation(avgAggregationBuilder)
//				.aggregation(maxAggregationBuilder).aggregation(minAggregationBuilder);

//此处定义分割线方便后面处理
String SEPARATOR = "<!!>";
//重点1 分组
TermsAggregationBuilder aggregation = AggregationBuilders.terms("name").field("name").order(Terms.Order.aggregation("name", true));

String scriptStr = "doc['name'].value +'" + SEPARATOR + "' + doc['age'].value" + SEPARATOR + "' + doc['sex'].value";

Script script = new Script(ScriptType.INLINE, Script.DEFAULT_SCRIPT_LANG, scriptStr, new HashMap<>());

//重点2 子聚合添加script
aggregation.script(script).subAggregation(sumAggregationBuilder).subAggregation(avgAggregationBuilder).
		subAggregation(maxAggregationBuilder).subAggregation(minAggregationBuilder);
//重点3 添加aggregation到sourceBuilder
sourceBuilder.aggregation(aggregation);
try {
	//查询索引对象
	SearchRequest searchRequest = new SearchRequest(index);
	searchRequest.types(type);
	searchRequest.source(sourceBuilder);
	SearchResponse searchResponse = client.search(searchRequest).get();
	System.out.println(searchResponse);

	List<Aggregation> aggregations = searchResponse.getAggregations().asList();
	StringTerms stringTerms = (StringTerms) aggregations.get(0);
	for (StringTerms.Bucket bucket : stringTerms.getBuckets()) {
		// 分组的字段使用#号分割
		String key = bucket.getKeyAsString();
		//多字段分组处理
		if (key.contains(SEPARATOR)) {
			String arr[] = key.split(SEPARATOR);
			String name = arr[0];
			String age = arr[1];
			String sex = arr[2];
		} else {
			//单字段分组处理
			String name = key;
		}

		//
		InternalValueCount valueCount = bucket.getAggregations().get("count");
		System.out.println(valueCount.getValue());

		InternalSum internalSum = bucket.getAggregations().get("sum");
		System.out.println(internalSum.getValue());

		InternalAvg internalAvg = bucket.getAggregations().get("avg");
		System.out.println(internalAvg.getValue());

		InternalMin internalMin = bucket.getAggregations().get("min");
		System.out.println(internalMin.getValue());

		InternalMax internalMax = bucket.getAggregations().get("max");
		System.out.println(internalMax.getValue());
	}
} catch (InterruptedException | ExecutionException e) {
	e.printStackTrace();
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值