本文整理匯總了Java中org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder類的典型用法代碼示例。如果您正苦於以下問題:Java TermsBuilder類的具體用法?Java TermsBuilder怎麽用?Java TermsBuilder使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
TermsBuilder類屬於org.elasticsearch.search.aggregations.bucket.terms包,在下文中一共展示了TermsBuilder類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: createResponse
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
/**
* create a SearchResponse with the main search query (from the FileResource /api/_search/files)
*
* @param query
* @param aggregation
* @return
*/
private SearchResponse createResponse(String query, TermsBuilder aggregation) {
SearchResponse response;
if (StringUtils.isNotEmpty(query)) {
response = elasticsearchTemplate.getClient().prepareSearch(Constants.INDEX_NAME)
.setTypes(Constants.TYPE_NAME)
//ici nous utilisons la même querybuilder que dans la recherche principale pour obtenir justement
//le même filtrage sur les versions courantes
.setQuery(Queries.constructQuery(query))
.addAggregation(aggregation)
.execute().actionGet();
} else {
response = elasticsearchTemplate.getClient().prepareSearch(Constants.INDEX_NAME)
.setTypes(Constants.TYPE_NAME)
.addAggregation(aggregation)
.execute().actionGet();
}
return response;
}
示例2: aggregateByRawField
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
@Override
public Map<String, Long> aggregateByRawField(String field, String filtre) {
TermsBuilder aggregation = AggregationBuilders.terms("top_" + field)
.field(field + ".raw")
.size(0)// le résultat n'est pas complet si on ne précise pas la taille, 0 : infini
// (voir : https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations-bucket-terms-aggregation.html#_size)
.order(Terms.Order.aggregation("_count", false));
SearchResponse response = createResponse(filtre, aggregation);
Map<String, Aggregation> results = response.getAggregations().asMap();
StringTerms topField = (StringTerms) results.get("top_" + field);
//sur l'ensemble des buckets, triés par ordre décroissant sur le nombre de documents
// on retourne une Map (LinkedHashMap) pour conserver l'ordre avec la clé, le nom du champ (exemple version), et la valeur, le nombre de docs
//exemple :
// "trunk" -> 34012
// "branche_1" -> 35800
return topField.getBuckets()
.stream()
.sorted(Comparator.comparing(Terms.Bucket::getDocCount).reversed())
.collect(
Collectors.toMap(bucket -> bucket.getKeyAsString(), bucket -> bucket.getDocCount(), (v1, v2) -> v1, LinkedHashMap::new
));
}
示例3: parse
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
public TermsBuilder parse(List<GroupingElement> elements, QueryState state){
List<Column> groups = new ArrayList<Column>();
for(GroupingElement grouping : elements){
for(Set<Expression> expressions : grouping.enumerateGroupingSets()){
for(Expression e : expressions) groups.add((Column) e.accept(this, state) );
}
}
// to find case sensitive group by definitions which ES needs
for(Column groupby : groups){
if(groupby.getOp() != Operation.NONE){
state.addException("Can not use function '"+groupby.getAggName()+"' as GROUP BY, please use an alias to group by a function");
return null;
}
}
Heading.fixColumnReferences(state.originalSql()+";", "group by.+", "\\W", groups);
for(Column g : groups){
Column s = state.getHeading().getColumnByLabel(g.getAggName());
if(s == null ){
state.addException("Group by '"+g.getColumn()+"' not defined in SELECT");
}else{
// add column from select to this group (when referenced through an alias)
g.setColumn(s.getColumn());
}
}
return buildAggregationQuery(groups, 0, state);
}
示例4: buildAggregationQuery
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
/**
* Adds aggregations recursively
* All metric columns are added to last aggregation
* @param aggs
* @param index
* @param metrics
* @return
*/
private TermsBuilder buildAggregationQuery(List<Column> aggs, int index, QueryState state){
Column agg = aggs.get(index);
TermsBuilder result = null;
if(aggs.get(index).getOp() == Operation.NONE){
result = AggregationBuilders.terms(agg.getAggName()).field(agg.getColumn());
result.size(state.getIntProp(Utils.PROP_FETCH_SIZE, 10000));
}
if(index < aggs.size() - 1) result.subAggregation(buildAggregationQuery(aggs, index+1, state));
else addMetrics(result, state.getHeading(), true);
return result;
}
示例5: addDistinctAggregation
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
public TermsBuilder addDistinctAggregation(QueryState state){
List<Column> distinct = new ArrayList<Column>();
for(Column s : state.getHeading().columns()){
if(s.getOp() == Operation.NONE && s.getCalculation() == null) distinct.add(s);
}
return buildAggregationQuery(distinct, 0, state);
}
示例6: makeGroupAgg
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
/**
* 分組查的聚合函數
*
* @param field
* @return
* @throws SqlParseException
*/
public AggregationBuilder<?> makeGroupAgg(Field field) throws SqlParseException {
if (field instanceof MethodField) {
return makeRangeGroup((MethodField) field);
} else {
TermsBuilder termsBuilder = AggregationBuilders.terms(field.getName()).field(field.getName());
groupMap.put(field.getName(), new KVValue("KEY", termsBuilder));
return termsBuilder;
}
}
示例7: getNodeTimeseriesStatistics
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
@Override
public List<NodeTimeseriesStatistics> getNodeTimeseriesStatistics(String tenantId, Criteria criteria, long interval) {
String index = client.getIndex(tenantId);
if (!refresh(index)) {
return null;
}
AvgBuilder avgBuilder = AggregationBuilders
.avg("avg")
.field(ElasticsearchUtil.ACTUAL_FIELD);
TermsBuilder componentsBuilder = AggregationBuilders
.terms("components")
.field("componentType")
.size(criteria.getMaxResponseSize())
.subAggregation(avgBuilder);
DateHistogramBuilder histogramBuilder = AggregationBuilders
.dateHistogram("histogram")
.interval(interval)
.field(ElasticsearchUtil.TIMESTAMP_FIELD)
.subAggregation(componentsBuilder);
BoolQueryBuilder query = buildQuery(criteria, ElasticsearchUtil.TRANSACTION_FIELD, NodeDetails.class);
SearchRequestBuilder request = getNodeDetailsRequest(index, criteria, query, 0)
.addAggregation(histogramBuilder);
SearchResponse response = getSearchResponse(request);
DateHistogram histogram = response.getAggregations().get("histogram");
return histogram.getBuckets().stream()
.map(AnalyticsServiceElasticsearch::toNodeTimeseriesStatistics)
.collect(Collectors.toList());
}
示例8: createStringSearchBuilder
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
private SearchRequestBuilder createStringSearchBuilder(Collection<FieldInfo> fields) {
SearchRequestBuilder builder = client.prepareSearch(indexName);
for(FieldInfo info : fields) {
TermsBuilder tokenBuilder = AggregationBuilders.terms(TERMS_AGG + info.getFullPath())
.field(info.getFullPath())
.minDocCount(props.getStringTokenMinOccurent())
.size(props.getStringTokenLimit());
builder.addAggregation(createNestedIfNecessary(info, tokenBuilder));
ValueCountBuilder countBuilder = AggregationBuilders.count(VALUE_COUNT_AGG + info.getFullPath()).field(info.getFullPath());
QueryBuilder filter = new BoolQueryBuilder().filter(new ExistsQueryBuilder(info.getFullPath()));
FilterAggregationBuilder filterBuilder = AggregationBuilders.filter(FILTER_AGG + info.getFullPath()).filter(filter).subAggregation(countBuilder);
builder.addAggregation(createNestedIfNecessary(info, filterBuilder));
}
builder.setSize(ZERO_ITEMS);
return builder;
}
示例9: SimpleAggregationBuilder
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
public SimpleAggregationBuilder(PB parentBuilder, TermsBuilder terms, String field, Integer size) {
super(parentBuilder);
if(size!=null){
terms.size(size);
}
if(StringUtils.isNotBlank(field)){
terms.field(field);
}
terms.order(Terms.Order.count(false));//COUNT_DESC
this.aggsBuilder = terms;
}
示例10: computeDocuments
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
private void computeDocuments(Credentials credentials, //
Company[] companies, String[] companyIds) {
ElasticClient elastic = Start.get().getElasticClient();
String alias = elastic.toAlias(credentials.backendId(), DOCUMENT_TYPE);
BoolQueryBuilder query = QueryBuilders.boolQuery()//
.must(QueryBuilders.termsQuery(COMPANY_ID, companyIds));
TermsBuilder aggBuilder = AggregationBuilders.terms("documents")//
.field(COMPANY_ID).include(companyIds)//
.subAggregation(AggregationBuilders.terms("waiting")//
.field(STATUS).include(statuses));
Terms agg = (Terms) elastic.prepareSearch()//
.setIndices(alias).setTypes(DOCUMENT_TYPE)//
.setQuery(query)//
.addAggregation(aggBuilder)//
.setSize(0)//
.get()//
.getAggregations()//
.get("documents");
for (Company company : companies) {
Bucket bucket = agg.getBucketByKey(company.id);
if (bucket != null) {
Terms agg2 = (Terms) bucket.getAggregations().get("waiting");
bucket = agg2.getBucketByKey(CLASSIFIED_STATUS);
company.docsToAnalyze = bucket == null ? 0 : bucket.getDocCount();
bucket = agg2.getBucketByKey(ANALYZED_STATUS);
company.docsToProcess = bucket == null ? 0 : bucket.getDocCount();
}
}
}
示例11: computeNotifications
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
private void computeNotifications(Credentials credentials, //
Company[] companies, String[] companyIds) {
ElasticClient elastic = Start.get().getElasticClient();
String alias = elastic.toAlias(credentials.backendId(), NOTIFICATION_TYPE);
String mainRole = getMainRole(credentials);
BoolQueryBuilder query = QueryBuilders.boolQuery()//
.must(QueryBuilders.termsQuery(COMPANY_ID, companyIds));
BoolQueryBuilder subAggQuery = QueryBuilders.boolQuery()//
.must(QueryBuilders.termQuery(mainRole + ".show", true))//
.mustNot(QueryBuilders.existsQuery(mainRole + ".readAt"));
TermsBuilder aggBuilder = AggregationBuilders.terms("notifications")//
.field(COMPANY_ID).include(companyIds)//
.subAggregation(AggregationBuilders.filter("notread")//
.filter(subAggQuery));
Terms agg = (Terms) elastic.prepareSearch()//
.setIndices(alias).setTypes(NOTIFICATION_TYPE)//
.setQuery(query)//
.addAggregation(aggBuilder)//
.setSize(0)//
.get()//
.getAggregations()//
.get("notifications");
for (Company company : companies) {
Bucket bucket = agg.getBucketByKey(company.id);
if (bucket != null) {
Filter agg2 = (Filter) bucket.getAggregations().get("notread");
company.notifications = agg2 == null ? 0 : agg2.getDocCount();
}
}
}
示例12: buildAggregation
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
private AbstractAggregationBuilder buildAggregation(StatsTrendRequest request) {
DateHistogram.Interval interval = Utils.getHistogramInterval(request.getPeriod());
AbstractAggregationBuilder dateHistogramBuilder = Utils.buildDateHistogramAggregation(request.getTimestamp(), interval)
.subAggregation(Utils.buildExtendedStatsAggregation(request.getField()))
.subAggregation(Utils.buildPercentileAggregation(request.getField()));
if (CollectionUtils.isNullOrEmpty(getParameter().getNesting())) {
return dateHistogramBuilder;
}
TermsBuilder rootBuilder = null;
TermsBuilder termsBuilder = null;
for (String field : getParameter().getNesting()) {
if (null == termsBuilder) {
termsBuilder = AggregationBuilders.terms(Utils.sanitizeFieldForAggregation(field)).field(field);
} else {
TermsBuilder tempBuilder = AggregationBuilders.terms(Utils.sanitizeFieldForAggregation(field)).field(field);
termsBuilder.subAggregation(tempBuilder);
termsBuilder = tempBuilder;
}
termsBuilder.size(0);
if (null == rootBuilder) {
rootBuilder = termsBuilder;
}
}
termsBuilder.subAggregation(dateHistogramBuilder);
return rootBuilder;
}
示例13: convert
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
@Override
public AggregationBuilder convert(QueryConverter queryConverter, Aggregation aggregation) {
TermsBuilder result = terms(getName(aggregation));
addField(aggregation, result);
addScript(aggregation, result);
Integer limit = aggregation.getInteger("limit");
if (limit != null) {
result.size(limit);
}
// todo - add ordering
Terms.Order order = Terms.Order.count(false);
Sort sort = Coerce.to(aggregation.get("order"), Sort.class, null);
if (sort != null) {
boolean asc = Sort.Direction.Ascending.equals(sort.getDirection());
if (Sort.Type.Count.equals(sort.getType())) {
order = Terms.Order.count(asc);
} else if (Sort.Type.Lexical.equals(sort.getType())) {
order = Terms.Order.term(asc);
}
}
result.order(order);
addSubAggs(queryConverter, aggregation, result);
return result;
}
示例14: getFacetBuilder
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
public static AggregationBuilder getFacetBuilder(MultiValueFacet multiValueFacet) {
FacetConfiguration facetConfiguration = multiValueFacet.getFacetConfiguration();
JSONObject facetData = facetConfiguration.getData();
if (multiValueFacet.isStatic()) {
return null;
}
TermsBuilder termsFacetBuilder = AggregationBuilders.terms(facetConfiguration.getFieldName());
if (facetData.has("maxTerms")) {
termsFacetBuilder.size(facetData.getInt("maxTerms"));
}
termsFacetBuilder.field(facetConfiguration.getFieldName());
return termsFacetBuilder;
}
示例15: buildFacets
import org.elasticsearch.search.aggregations.bucket.terms.TermsBuilder; //導入依賴的package包/類
@Override
public List<AggregationBuilder> buildFacets() {
TermsBuilder termsBuilder = AggregationBuilders.terms(getEsFieldName()).field(getEsFieldName()).size(size);
MissingBuilder missingBuilder = AggregationBuilders.missing("missing_" + getEsFieldName()).field(getEsFieldName());
// Elastic search has a bug with excludes so don't use it. https://github.com/elastic/elasticsearch/issues/18575
// if (exclude != null) {
// termsBuilder.exclude(exclude);
// }
return Lists.newArrayList(termsBuilder, missingBuilder);
}