當前位置: 首頁>>代碼示例>>Java>>正文


Java BoolQueryBuilder.filter方法代碼示例

本文整理匯總了Java中org.elasticsearch.index.query.BoolQueryBuilder.filter方法的典型用法代碼示例。如果您正苦於以下問題:Java BoolQueryBuilder.filter方法的具體用法?Java BoolQueryBuilder.filter怎麽用?Java BoolQueryBuilder.filter使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.elasticsearch.index.query.BoolQueryBuilder的用法示例。


在下文中一共展示了BoolQueryBuilder.filter方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: preparse

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private QueryBuilder preparse(String q, int timezoneOffset) {
    // detect usage of OR connector usage.
    q = fixQueryMistakes(q);
    List<String> terms = splitIntoORGroups(q); // OR binds stronger than AND
    if (terms.size() == 0) return QueryBuilders.constantScoreQuery(QueryBuilders.matchAllQuery());
    
    // special handling
    if (terms.size() == 1) return parse(terms.get(0), timezoneOffset);

    // generic handling
    BoolQueryBuilder aquery = QueryBuilders.boolQuery();
    for (String t: terms) {
        QueryBuilder partial = parse(t, timezoneOffset);
        aquery.filter(partial);
    }
    return aquery;
}
 
開發者ID:yacy,項目名稱:yacy_grid_mcp,代碼行數:18,代碼來源:LoklakQuery.java

示例2: applyAccessControlQuery

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private void applyAccessControlQuery(FactSearchCriteria criteria, BoolQueryBuilder rootQuery) {
  // Query to verify that user has access to Fact ...
  BoolQueryBuilder accessQuery = boolQuery()
          // ... if Fact is public.
          .should(termQuery("accessMode", FactDocument.AccessMode.Public))
          // ... if AccessMode == Explicit user must be in ACL.
          .should(boolQuery()
                  .filter(termQuery("accessMode", FactDocument.AccessMode.Explicit))
                  .filter(termQuery("acl", criteria.getCurrentUserID()))
          )
          // ... if AccessMode == RoleBased user must be in ACL or have access to the owning Organization.
          .should(boolQuery()
                  .filter(termQuery("accessMode", FactDocument.AccessMode.RoleBased))
                  .filter(boolQuery()
                          .should(termQuery("acl", criteria.getCurrentUserID()))
                          .should(termsQuery("organizationID", criteria.getAvailableOrganizationID()))
                  )
          );

  // Always apply access control query.
  rootQuery.filter(accessQuery);
}
 
開發者ID:mnemonic-no,項目名稱:act-platform,代碼行數:23,代碼來源:FactSearchManager.java

示例3: applyFieldStrategy

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private void applyFieldStrategy(BoolQueryBuilder rootQuery, Function<String, QueryBuilder> fieldQueryResolver,
                                Set<? extends FactSearchCriteria.FieldStrategy> fieldStrategies,
                                FactSearchCriteria.MatchStrategy matchStrategy) {
  // Determine all fields to query.
  Set<String> fieldsToQuery = fieldStrategies.stream()
          .flatMap(strategy -> strategy.getFields().stream())
          .collect(Collectors.toSet());

  BoolQueryBuilder strategyQuery = boolQuery();
  for (String field : fieldsToQuery) {
    if (matchStrategy == FactSearchCriteria.MatchStrategy.all) {
      // Field query must match all fields.
      strategyQuery.filter(fieldQueryResolver.apply(field));
    } else {
      // Field query should match at least one field.
      strategyQuery.should(fieldQueryResolver.apply(field));
    }
  }

  rootQuery.filter(strategyQuery);
}
 
開發者ID:mnemonic-no,項目名稱:act-platform,代碼行數:22,代碼來源:FactSearchManager.java

示例4: toQuery

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private BoolSearch toQuery(Context context) {
	BoolQueryBuilder query = QueryBuilders.boolQuery()//
			.filter(QueryBuilders.termQuery(FIELD_BACKEND_ID, SpaceContext.backendId()));

	String username = context.get(FIELD_USERNAME);
	if (!Strings.isNullOrEmpty(username))
		query.filter(QueryBuilders.termQuery(FIELD_USERNAME, username));

	String email = context.get(FIELD_EMAIL);
	if (!Strings.isNullOrEmpty(email))
		query.filter(QueryBuilders.termQuery(FIELD_EMAIL, email));

	String level = context.get(FIELD_CREDENTIALS_LEVEL);
	if (!Strings.isNullOrEmpty(level))
		query.filter(QueryBuilders.termQuery(FIELD_CREDENTIALS_LEVEL, level));

	BoolSearch search = new BoolSearch(SPACEDOG_BACKEND, TYPE, query, //
			context.query().getInteger(PARAM_FROM, 0), //
			context.query().getInteger(PARAM_SIZE, 10));

	return search;
}
 
開發者ID:spacedog-io,項目名稱:spacedog-server,代碼行數:23,代碼來源:CredentialsResource.java

示例5: doPurgeBackend

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private Optional<DeleteByQueryResponse> doPurgeBackend(DateTime before, //
		Optional<String> optBackendId) {

	BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery()//
			.filter(QueryBuilders.rangeQuery(FIELD_RECEIVED_AT).lt(before.toString()));

	if (optBackendId.isPresent())
		boolQueryBuilder.filter(//
				QueryBuilders.termQuery("credentials.backendId", optBackendId.get()));

	String query = new QuerySourceBuilder().setQuery(boolQueryBuilder).toString();

	DeleteByQueryResponse delete = Start.get().getElasticClient()//
			.deleteByQuery(query, SPACEDOG_BACKEND, TYPE);

	// TODO why return an optional?
	// return directly the response
	return Optional.of(delete);
}
 
開發者ID:spacedog-io,項目名稱:spacedog-server,代碼行數:20,代碼來源:LogResource.java

示例6: doGetLogs

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private SearchResponse doGetLogs(int from, int size, Optional<String> backendId) {

		BoolQueryBuilder query = QueryBuilders.boolQuery();

		if (backendId.isPresent())
			query.filter(QueryBuilders.termQuery("credentials.backendId", backendId.get()));

		return Start.get().getElasticClient()//
				.prepareSearch(SPACEDOG_BACKEND, TYPE)//
				.setTypes(TYPE)//
				.setQuery(query)//
				.addSort(FIELD_RECEIVED_AT, SortOrder.DESC)//
				.setFrom(from)//
				.setSize(size)//
				.get();
	}
 
開發者ID:spacedog-io,項目名稱:spacedog-server,代碼行數:17,代碼來源:LogResource.java

示例7: queryWithConstraints

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
public List<Map<String, Object>> queryWithConstraints(final String indexName, final String fieldName, final String fieldValue, final Map<String, String> constraints, boolean latest) throws IOException {
    SearchRequestBuilder request = this.elasticsearchClient.prepareSearch(indexName)
            .setSearchType(SearchType.QUERY_THEN_FETCH)
            .setFrom(0);

    BoolQueryBuilder bFilter = QueryBuilders.boolQuery();
    bFilter.filter(QueryBuilders.constantScoreQuery(QueryBuilders.constantScoreQuery(QueryBuilders.termQuery(fieldName, fieldValue))));
    for (Object o : constraints.entrySet()) {
        @SuppressWarnings("rawtypes")
        Map.Entry entry = (Map.Entry) o;
        bFilter.filter(QueryBuilders.constantScoreQuery(QueryBuilders.termQuery((String) entry.getKey(), ((String) entry.getValue()).toLowerCase())));
    }
    request.setQuery(bFilter);
    
    // get response
    SearchResponse response = request.execute().actionGet();

    // evaluate search result
    ArrayList<Map<String, Object>> result = new ArrayList<Map<String, Object>>();
    SearchHit[] hits = response.getHits().getHits();
    for (SearchHit hit: hits) {
        Map<String, Object> map = hit.getSourceAsMap();
        result.add(map);
    }

    return result;
}
 
開發者ID:yacy,項目名稱:yacy_grid_mcp,代碼行數:28,代碼來源:ElasticsearchClient.java

示例8: query

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
@Override
    public Object query(Person person) {
        List<Map<String, Object>> result = new ArrayList<>();
        try {
            BoolQueryBuilder boolBuilder = QueryBuilders.boolQuery();
            if (person.getName() != null) {
//	            boolBuilder.must(QueryBuilders.matchQuery("name", person.getName()));
                boolBuilder.should(QueryBuilders.matchQuery("name", person.getName()));
            }
            if (person.getIntroduce() != null) {
//	            boolBuilder.must(QueryBuilders.matchQuery("introduce", person.getIntroduce()));
                boolBuilder.should(QueryBuilders.matchQuery("introduce", person.getIntroduce()));
            }

            //大於age,小於age+10
            if (person.getAge() > 0) {
                RangeQueryBuilder rangeQuery = QueryBuilders.rangeQuery("age");
                rangeQuery.from(person.getAge());
                rangeQuery.to(person.getAge() + 10);
                boolBuilder.filter(rangeQuery);
            }
            SearchRequestBuilder builder = transportClient.prepareSearch(index)
                    .setTypes(type)
                    .setSearchType(SearchType.QUERY_THEN_FETCH)
                    .setQuery(boolBuilder)
                    .setFrom(0)
                    .setSize(10);
            log.info(String.valueOf(builder));
            SearchResponse response = builder.get();
            response.getHits().forEach((s) -> result.add(s.getSource()));
        } catch (Exception e) {
            e.printStackTrace();
            log.error(e.getMessage(), e);
        }
        return result;
    }
 
開發者ID:jeikerxiao,項目名稱:SpringBootStudy,代碼行數:37,代碼來源:PersonDaoImpl.java

示例9: search

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
public SearchHits search(String backendId, String type, Object... terms) {

		if (terms.length % 2 == 1)
			throw Exceptions.illegalArgument(//
					"invalid search terms %s: missing term value", Arrays.toString(terms));

		BoolQueryBuilder builder = QueryBuilders.boolQuery();
		for (int i = 0; i < terms.length; i = i + 2)
			builder.filter(QueryBuilders.termQuery(terms[i].toString(), terms[i + 1]));

		SearchResponse response = Start.get().getElasticClient()//
				.prepareSearch(backendId, type).setTypes(type).setQuery(builder).get();

		return response.getHits();
	}
 
開發者ID:spacedog-io,項目名稱:spacedog-server,代碼行數:16,代碼來源:DataStore.java

示例10: applySimpleFilterQueries

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private void applySimpleFilterQueries(FactSearchCriteria criteria, BoolQueryBuilder rootQuery) {
  if (!CollectionUtils.isEmpty(criteria.getFactID())) {
    rootQuery.filter(termsQuery("_id", criteria.getFactID()));
  }

  if (!CollectionUtils.isEmpty(criteria.getFactTypeID())) {
    rootQuery.filter(termsQuery("typeID", criteria.getFactTypeID()));
  }

  if (!CollectionUtils.isEmpty(criteria.getFactTypeName())) {
    rootQuery.filter(termsQuery("typeName", criteria.getFactTypeName()));
  }

  if (!CollectionUtils.isEmpty(criteria.getFactValue())) {
    rootQuery.filter(termsQuery("value", criteria.getFactValue()));
  }

  if (!CollectionUtils.isEmpty(criteria.getInReferenceTo())) {
    rootQuery.filter(termsQuery("inReferenceTo", criteria.getInReferenceTo()));
  }

  if (!CollectionUtils.isEmpty(criteria.getOrganizationID())) {
    rootQuery.filter(termsQuery("organizationID", criteria.getOrganizationID()));
  }

  if (!CollectionUtils.isEmpty(criteria.getOrganizationName())) {
    rootQuery.filter(termsQuery("organizationName", criteria.getOrganizationName()));
  }

  if (!CollectionUtils.isEmpty(criteria.getSourceID())) {
    rootQuery.filter(termsQuery("sourceID", criteria.getSourceID()));
  }

  if (!CollectionUtils.isEmpty(criteria.getSourceName())) {
    rootQuery.filter(termsQuery("sourceName", criteria.getSourceName()));
  }

  if (!CollectionUtils.isEmpty(criteria.getObjectID())) {
    rootQuery.filter(nestedQuery("objects", termsQuery("objects.id", criteria.getObjectID()), ScoreMode.None));
  }

  if (!CollectionUtils.isEmpty(criteria.getObjectTypeID())) {
    rootQuery.filter(nestedQuery("objects", termsQuery("objects.typeID", criteria.getObjectTypeID()), ScoreMode.None));
  }

  if (!CollectionUtils.isEmpty(criteria.getObjectTypeName())) {
    rootQuery.filter(nestedQuery("objects", termsQuery("objects.typeName", criteria.getObjectTypeName()), ScoreMode.None));
  }

  if (!CollectionUtils.isEmpty(criteria.getObjectValue())) {
    rootQuery.filter(nestedQuery("objects", termsQuery("objects.value", criteria.getObjectValue()), ScoreMode.None));
  }

  if (criteria.getRetracted() != null) {
    rootQuery.filter(termQuery("retracted", (boolean) criteria.getRetracted()));
  }
}
 
開發者ID:mnemonic-no,項目名稱:act-platform,代碼行數:58,代碼來源:FactSearchManager.java

示例11: version

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
@GET
@Path("version")
@Produces(APPLICATION_JSON)
public List<RundeckXO> version(
        @DefaultValue("10") @QueryParam("l") int limit,
        @QueryParam("r") String repository,
        @QueryParam("g") String groupId,
        @QueryParam("a") String artifactId,
        @QueryParam("c") String classifier,
        @QueryParam("p") String extension
) {

    log.debug("param value, repository: {}, limit: {}, groupId: {}, artifactId: {}, classifier: {}, extension: {}", repository, limit, groupId, artifactId, classifier, extension);

    BoolQueryBuilder query = boolQuery();
    query.filter(termQuery("format", "maven2"));

    if (!isBlank(repository)) {
        query.filter(termQuery("repository_name", repository));
    }
    if (!isBlank(groupId)) {
        query.filter(termQuery("attributes.maven2.groupId", groupId));
    }
    if (!isBlank(artifactId)) {
        query.filter(termQuery("attributes.maven2.artifactId", artifactId));
    }
    if (!isBlank(classifier)) {
        query.filter(termQuery("assets.attributes.maven2.classifier", classifier));
    }
    if (!isBlank(extension)) {
        query.filter(termQuery("assets.attributes.maven2.extension", extension));
    }

    log.debug("rundeck maven version query: {}", query);
    SearchResponse result = searchService.search(
            query,
            Collections.singletonList(new FieldSortBuilder("assets.attributes.content.last_modified").order(SortOrder.DESC)),
            0,
            limit
    );
    return Arrays.stream(result.getHits().hits())
            .map(this::his2RundeckXO)
            .collect(Collectors.toList());
}
 
開發者ID:nongfenqi,項目名稱:nexus3-rundeck-plugin,代碼行數:45,代碼來源:RundeckMavenResource.java

示例12: search

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
@Override
public Collection<AddOnInfoSummary> search(AddOnType type, String query, String tag) throws IOException {
	BoolQueryBuilder boolQB = QueryBuilders.boolQuery();
	if (type != null) {
		//Exact match on type
		boolQB.filter(QueryBuilders.matchQuery("type", type));
	}
	if (tag != null) {	
		boolQB.filter(QueryBuilders.matchQuery("tags", tag));
	}
	if (query != null) {
		//Exact match on id(Highest priority)
		boolQB.should(QueryBuilders.termQuery("_id", query).boost(1700.0f));

		//Exact match on tag(High priority)
		boolQB.should(QueryBuilders.termQuery("tags", query).boost(1500.0f));

		//Prefix match of module name(Medium priority)
		boolQB.should(QueryBuilders.prefixQuery("name", query).boost(4.0f));

		//Query is subset of module name(Medium priority)
		boolQB.should(QueryBuilders.matchQuery("name", query).boost(2.0f));

		//Description matches query either completely or partially(Low priority)
		boolQB.should(QueryBuilders.matchQuery("description", query).boost(0.5f));

		//Allow for spelling mistake while searching for a particular module
		boolQB.should(QueryBuilders.matchPhraseQuery("name", query).slop(2).fuzziness("AUTO"));
		boolQB.minimumNumberShouldMatch(1);
	}
	
	BoostingQueryBuilder boostingQB = QueryBuilders.boostingQuery();
	boostingQB.positive(boolQB);

	//Decrease ranking of those modules which are "Deprecated" or "Inactive"
	boostingQB.negative(QueryBuilders.termsQuery("status", "DEPRECATED", "INACTIVE"));
	boostingQB.negativeBoost(0.01f);
	
	SearchResult result = client.execute(new Search.Builder(
			new SearchSourceBuilder().size(SEARCH_SIZE).query(boostingQB).toString())
			.addIndex(AddOnInfoAndVersions.ES_INDEX)
			.build());
	return result.getHits(AddOnInfoAndVersions.class).stream()
			.map(sr -> new AddOnInfoSummary(sr.source))
			.collect(Collectors.toList());
}
 
開發者ID:openmrs,項目名稱:openmrs-contrib-addonindex,代碼行數:47,代碼來源:ElasticSearchIndex.java

示例13: buildAllThings

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
private QueryBuilder buildAllThings(String query, String motivations, String allDateRanges, String users,
    String type, String within) {
List<QueryBuilder> queryList = new ArrayList<>();

BoolQueryBuilder must = QueryBuilders.boolQuery();

if (null != query) {
    // String tidyQuery =
    // annotationUtils.convertSpecialCharacters(query);
    String tidyQuery = query;
    if (null == type) {
	must = must.must(QueryBuilders.multiMatchQuery(tidyQuery, "body", "target", "bodyURI", "targetURI")
		.type(Type.PHRASE));
    }
    if ("topic".equals(type)) {
	must = must.must(QueryBuilders.multiMatchQuery(tidyQuery, "bodyURI"));
    }
}

if (null != motivations) {
    List<String> motivationsList = annotationUtils.getListFromSpaceSeparatedTerms(motivations);
    if (motivations.contains("non-")) {

	if (motivationsList.size() > 1) {
	    throw new SearchQueryException(
		    "You have a motivation that is a non-<motivation>, there can only be one motivation in this instance.");
	} else {
	    String tidyMotivations = motivations.replaceAll("non-", "");
	    queryList.add(QueryBuilders.existsQuery(AnnotationSearchConstants.FIELD_MOTIVATIONS));

	    must.mustNot(QueryBuilders.termQuery(AnnotationSearchConstants.FIELD_MOTIVATIONS, tidyMotivations));
	}
    } else {
	must.filter(QueryBuilders.termsQuery(AnnotationSearchConstants.FIELD_MOTIVATIONS, motivationsList));
    }
}

if (null != allDateRanges) {
    queryList.add(buildDates("created", allDateRanges));
}

if (null != users) {
    List<String> usersList = annotationUtils.getListFromSpaceSeparatedTerms(users);
    must.filter(QueryBuilders.termsQuery("creators", usersList));
}

for (QueryBuilder eachQuery : queryList) {
    must = must.must(eachQuery);
}

if (null != within) {
    String decodedWithinUrl = annotationUtils.decodeWithinUrl(within);
    if (null != decodedWithinUrl) {
	must.must(QueryBuilders.matchQuery("manifest", decodedWithinUrl));
    }
}

return must;
   }
 
開發者ID:dlcs,項目名稱:the-mathmos-server,代碼行數:60,代碼來源:AnnotationSearchServiceImpl.java

示例14: contribute

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
@Override
public void contribute(final BoolQueryBuilder query, final String type, final String value) {
  if (value != null) {
    query.filter(QueryBuilders.termQuery(type, value));
  }
}
 
開發者ID:sonatype,項目名稱:nexus-public,代碼行數:7,代碼來源:DefaultSearchContribution.java

示例15: pushByTags

import org.elasticsearch.index.query.BoolQueryBuilder; //導入方法依賴的package包/類
/**
 * Check this page for specific json messages:
 * http://docs.aws.amazon.com/sns/latest/dg/mobile-push-send-custommessage.
 * html
 */
@Post("/push")
@Post("/push/")
@Post("/installation/push")
@Post("/installation/push/")
public Payload pushByTags(String body, Context context) {

	Credentials credentials = SpaceContext.checkUserCredentials();

	ObjectNode push = Json8.readObject(body);
	String appId = Json8.checkStringNotNullOrEmpty(push, APP_ID);
	JsonNode message = Json8.checkNode(push, MESSAGE, true).get();
	BadgeStrategy badge = getBadgeStrategy(push);
	ObjectNode objectMessage = toObjectMessage(message);

	BoolQueryBuilder query = QueryBuilders.boolQuery()//
			.filter(QueryBuilders.termQuery(APP_ID, appId));

	Optional<String> service = Json8.checkString(push, PUSH_SERVICE);
	if (service.isPresent())
		query.filter(QueryBuilders.termQuery(PUSH_SERVICE, service.get()));

	boolean usersOnly = Json8.checkBoolean(push, USERS_ONLY, false);
	if (usersOnly)
		query.filter(QueryBuilders.existsQuery(USER_ID));

	JsonNode tags = push.get(TAGS);
	if (tags != null) {
		Iterator<JsonNode> tagsIterator = tags.isObject()//
				? Iterators.singletonIterator(tags) : tags.elements();

		while (tagsIterator.hasNext()) {
			JsonNode tag = tagsIterator.next();
			query.filter(//
					QueryBuilders.termQuery(//
							toFieldPath(TAGS, TAG_KEY), //
							tag.get(TAG_KEY).asText()))//
					.filter(QueryBuilders.termQuery(//
							toFieldPath(TAGS, TAG_VALUE), //
							tag.get(TAG_VALUE).asText()));
		}
	}

	boolean refresh = context.query().getBoolean(PARAM_REFRESH, false);
	DataStore.get().refreshType(refresh, credentials.backendId(), TYPE);

	// TODO use a scroll to push to all installations found
	SearchHits hits = Start.get().getElasticClient()//
			.prepareSearch(credentials.backendId(), TYPE)//
			.setQuery(query)//
			.setFrom(0)//
			.setSize(1000)//
			.setVersion(false)//
			.setFetchSource(new String[] { USER_ID, ENDPOINT, PUSH_SERVICE, BADGE }, null)//
			.get()//
			.getHits();

	if (hits.totalHits() > 1000)
		return JsonPayload.error(HttpStatus.NOT_IMPLEMENTED, //
				"push to [%s] installations is a premium feature", hits.totalHits());

	PushLog log = new PushLog();

	for (SearchHit hit : hits.getHits()) {
		ObjectNode installation = Json8.readObject(hit.sourceAsString());
		pushToInstallation(log, hit.getId(), installation, objectMessage, credentials, badge);
		if (log.applicationDisabled)
			break;
	}

	return log.toPayload();
}
 
開發者ID:spacedog-io,項目名稱:spacedog-server,代碼行數:77,代碼來源:PushResource.java


注:本文中的org.elasticsearch.index.query.BoolQueryBuilder.filter方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。