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


Java RangeQueryBuilder類代碼示例

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


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

示例1: createRangeQuery

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
private static RangeQueryBuilder createRangeQuery(String name, Map<String, Object> rangeOperation,
    Float boost) {

  RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery(name+RAW_APPEND);
  for (Map.Entry<String, Object> it : rangeOperation.entrySet()) {
    if (it.getKey().equalsIgnoreCase(LTE)) {
      rangeQueryBuilder.lte(it.getValue());
    } else if (it.getKey().equalsIgnoreCase(LT)) {
      rangeQueryBuilder.lt(it.getValue());
    } else if (it.getKey().equalsIgnoreCase(GTE)) {
      rangeQueryBuilder.gte(it.getValue());
    } else if (it.getKey().equalsIgnoreCase(GT)) {
      rangeQueryBuilder.gt(it.getValue());
    }
  }
  if (isNotNull(boost)) {
    return rangeQueryBuilder.boost(boost);
  }
  return rangeQueryBuilder;
}
 
開發者ID:project-sunbird,項目名稱:sunbird-utils,代碼行數:21,代碼來源:ElasticSearchUtil.java

示例2: testUnsupportedQueries

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
public void testUnsupportedQueries() {
    RangeQueryBuilder rangeQuery1 = new RangeQueryBuilder("field").from("2016-01-01||/D").to("2017-01-01||/D");
    RangeQueryBuilder rangeQuery2 = new RangeQueryBuilder("field").from("2016-01-01||/D").to("now");
    PercolatorFieldMapper.verifyQuery(rangeQuery1);
    expectThrows(IllegalArgumentException.class, () -> PercolatorFieldMapper.verifyQuery(rangeQuery2));
    PercolatorFieldMapper.verifyQuery(new BoolQueryBuilder().must(rangeQuery1));
    expectThrows(IllegalArgumentException.class, () ->
            PercolatorFieldMapper.verifyQuery(new BoolQueryBuilder().must(rangeQuery2)));
    PercolatorFieldMapper.verifyQuery(new ConstantScoreQueryBuilder((rangeQuery1)));
    expectThrows(IllegalArgumentException.class, () ->
            PercolatorFieldMapper.verifyQuery(new ConstantScoreQueryBuilder(rangeQuery2)));
    PercolatorFieldMapper.verifyQuery(new BoostingQueryBuilder(rangeQuery1, new MatchAllQueryBuilder()));
    expectThrows(IllegalArgumentException.class, () ->
            PercolatorFieldMapper.verifyQuery(new BoostingQueryBuilder(rangeQuery2, new MatchAllQueryBuilder())));
    PercolatorFieldMapper.verifyQuery(new FunctionScoreQueryBuilder(rangeQuery1, new RandomScoreFunctionBuilder()));
    expectThrows(IllegalArgumentException.class, () ->
            PercolatorFieldMapper.verifyQuery(new FunctionScoreQueryBuilder(rangeQuery2, new RandomScoreFunctionBuilder())));

    HasChildQueryBuilder hasChildQuery = new HasChildQueryBuilder("_type", new MatchAllQueryBuilder(), ScoreMode.None);
    expectThrows(IllegalArgumentException.class, () -> PercolatorFieldMapper.verifyQuery(hasChildQuery));
    expectThrows(IllegalArgumentException.class, () -> PercolatorFieldMapper.verifyQuery(new BoolQueryBuilder().must(hasChildQuery)));

    HasParentQueryBuilder hasParentQuery = new HasParentQueryBuilder("_type", new MatchAllQueryBuilder(), false);
    expectThrows(IllegalArgumentException.class, () -> PercolatorFieldMapper.verifyQuery(hasParentQuery));
    expectThrows(IllegalArgumentException.class, () -> PercolatorFieldMapper.verifyQuery(new BoolQueryBuilder().must(hasParentQuery)));
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:27,代碼來源:PercolatorFieldMapperTests.java

示例3: range

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * @param operator operator <,>,<=,>=
 * @param field field name
 * @param stringValue field value
 * @return a range query
 */
static QueryBuilder range(String operator, String field, String stringValue) {
	String key = StringUtils.replaceAll(field, "[<>=\\s]+$", "");
	boolean nestedMode = nestedMode() && field.startsWith(PROPS_PREFIX);
	RangeQueryBuilder rfb = rangeQuery(nestedMode ? getValueFieldName(stringValue) : key);
	if (">".equals(operator)) {
		rfb.gt(getNumericValue(stringValue));
	} else if ("<".equals(operator)) {
		rfb.lt(getNumericValue(stringValue));
	} else if (">=".equals(operator)) {
		rfb.gte(getNumericValue(stringValue));
	} else if ("<=".equals(operator)) {
		rfb.lte(getNumericValue(stringValue));
	}
	if (nestedMode) {
		return nestedPropsQuery(keyValueBoolQuery(key, stringValue, rfb));
	} else {
		return rfb;
	}
}
 
開發者ID:Erudika,項目名稱:para-search-elasticsearch,代碼行數:26,代碼來源:ElasticSearchUtils.java

示例4: termRange

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
private static QueryBuilder termRange(Query q) {
	QueryBuilder qb = null;
	TermRangeQuery trq = (TermRangeQuery) q;
	if (!StringUtils.isBlank(trq.getField())) {
		String from = trq.getLowerTerm() != null ? Term.toString(trq.getLowerTerm()) : "*";
		String to = trq.getUpperTerm() != null ? Term.toString(trq.getUpperTerm()) : "*";
		boolean nestedMode = nestedMode() && trq.getField().matches(PROPS_REGEX);
		qb = rangeQuery(nestedMode ? getValueFieldNameFromRange(from, to) : trq.getField());
		if ("*".equals(from) && "*".equals(to)) {
			qb = matchAllQuery();
		}
		if (!"*".equals(from)) {
			((RangeQueryBuilder) qb).from(getNumericValue(from)).includeLower(trq.includesLower());
		}
		if (!"*".equals(to)) {
			((RangeQueryBuilder) qb).to(getNumericValue(to)).includeUpper(trq.includesUpper());
		}
		if (nestedMode) {
			qb = nestedPropsQuery(keyValueBoolQuery(trq.getField(), qb));
		}
	}
	return qb;
}
 
開發者ID:Erudika,項目名稱:para-search-elasticsearch,代碼行數:24,代碼來源:ElasticSearchUtils.java

示例5: setUp

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
@SuppressWarnings("unchecked")
@Before
public void setUp() throws Exception {
    doReturn(classValue).when(visitor).doGetPrimitiveFieldClass(any(PrimitiveStatement.class));

    doReturn(wildcardQueryBuilder).when(visitor).createWildcardQuery(anyString(), anyString());
    doReturn(boolQueryBuilder).when(visitor).createBoolQueryBuilder();
    doReturn(termQueryBuilder).when(visitor).createTermQuery(anyString(), any());
    doReturn(rangeQueryBuilder).when(visitor).createRangeQuery(anyString());

    doReturn(boolQueryBuilder).when(boolQueryBuilder).mustNot(any(QueryBuilder.class));
    doReturn(rangeQueryBuilder).when(rangeQueryBuilder).lt(any(RangeQueryBuilder.class));
    doReturn(rangeQueryBuilder).when(rangeQueryBuilder).lte(any(RangeQueryBuilder.class));
    doReturn(rangeQueryBuilder).when(rangeQueryBuilder).gt(any(RangeQueryBuilder.class));
    doReturn(rangeQueryBuilder).when(rangeQueryBuilder).gte(any(RangeQueryBuilder.class));

    // We'll test our enum-safe getter separately.
    doAnswer(answer -> answer.getArgumentAt(0, TestSearchConditionVisitor.ClassValue.class).getValue())
            .when(visitor).getEnumSafeValue(classValue);
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:21,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例6: testBuildSimpleLessThanExpression

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#buildSimpleExpression(PrimitiveStatement)} for the case where
 * we're building a {@link ConditionType#LESS_THAN} expression.
 */
@SuppressWarnings("unchecked")
@Test
public void testBuildSimpleLessThanExpression() throws Exception {
    final Object value = "hello";
    final String property = "property";

    doReturn(value).when(classValue).getValue();
    doReturn(LESS_THAN).when(statement).getCondition();
    doReturn(property).when(statement).getProperty();

    assertThat(visitor.buildSimpleExpression(statement), instanceOf(RangeQueryBuilder.class));

    verify(visitor).buildSimpleExpression(statement);
    verify(visitor).doGetPrimitiveFieldClass(statement);
    verify(visitor).validateNotCollectionCheck(statement, classValue);
    verify(visitor).createRangeQuery(property);
    verify(visitor).getEnumSafeValue(classValue);

    verify(statement).getProperty();
    verify(statement).getCondition();

    verify(rangeQueryBuilder).lt(value);

    verifyNoMoreCollaboration();
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:30,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例7: testBuildSimpleLessThanOrEqualsExpression

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#buildSimpleExpression(PrimitiveStatement)} for the case where
 * we're building a {@link ConditionType#LESS_OR_EQUALS} expression.
 */
@SuppressWarnings("unchecked")
@Test
public void testBuildSimpleLessThanOrEqualsExpression() throws Exception {
    final Object value = "hello";
    final String property = "property";

    doReturn(value).when(classValue).getValue();
    doReturn(LESS_OR_EQUALS).when(statement).getCondition();
    doReturn(property).when(statement).getProperty();

    assertThat(visitor.buildSimpleExpression(statement), instanceOf(RangeQueryBuilder.class));

    verify(visitor).buildSimpleExpression(statement);
    verify(visitor).doGetPrimitiveFieldClass(statement);
    verify(visitor).validateNotCollectionCheck(statement, classValue);
    verify(visitor).createRangeQuery(property);
    verify(visitor).getEnumSafeValue(classValue);

    verify(statement).getProperty();
    verify(statement).getCondition();

    verify(rangeQueryBuilder).lte(value);

    verifyNoMoreCollaboration();
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:30,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例8: testBuildSimpleGreaterThanExpression

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#buildSimpleExpression(PrimitiveStatement)} for the case where
 * we're building a {@link ConditionType#GREATER_THAN} expression.
 */
@SuppressWarnings("unchecked")
@Test
public void testBuildSimpleGreaterThanExpression() throws Exception {
    final Object value = "hello";
    final String property = "property";

    doReturn(value).when(classValue).getValue();
    doReturn(GREATER_THAN).when(statement).getCondition();
    doReturn(property).when(statement).getProperty();

    assertThat(visitor.buildSimpleExpression(statement), instanceOf(RangeQueryBuilder.class));

    verify(visitor).buildSimpleExpression(statement);
    verify(visitor).doGetPrimitiveFieldClass(statement);
    verify(visitor).validateNotCollectionCheck(statement, classValue);
    verify(visitor).createRangeQuery(property);
    verify(visitor).getEnumSafeValue(classValue);

    verify(statement).getProperty();
    verify(statement).getCondition();

    verify(rangeQueryBuilder).gt(value);

    verifyNoMoreCollaboration();
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:30,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例9: testBuildSimpleGreaterThanOrEqualsExpression

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#buildSimpleExpression(PrimitiveStatement)} for the case where
 * we're building a {@link ConditionType#GREATER_OR_EQUALS} expression.
 */
@SuppressWarnings("unchecked")
@Test
public void testBuildSimpleGreaterThanOrEqualsExpression() throws Exception {
    final Object value = "hello";
    final String property = "property";

    doReturn(value).when(classValue).getValue();
    doReturn(GREATER_OR_EQUALS).when(statement).getCondition();
    doReturn(property).when(statement).getProperty();

    assertThat(visitor.buildSimpleExpression(statement), instanceOf(RangeQueryBuilder.class));

    verify(visitor).buildSimpleExpression(statement);
    verify(visitor).doGetPrimitiveFieldClass(statement);
    verify(visitor).validateNotCollectionCheck(statement, classValue);
    verify(visitor).createRangeQuery(property);
    verify(visitor).getEnumSafeValue(classValue);

    verify(statement).getProperty();
    verify(statement).getCondition();

    verify(rangeQueryBuilder).gte(value);

    verifyNoMoreCollaboration();
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:30,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例10: testMergeQueryPartsForLessThan

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#mergeQueryParts(QueryBuilder, QueryBuilder)} for the case where our
 * current query part is a less than/less than or equal to.
 */
@Test
public void testMergeQueryPartsForLessThan() throws Exception {
    final RangeQueryBuilder previousPart = mock(RangeQueryBuilder.class);
    final RangeQueryBuilder currentPart = mock(RangeQueryBuilder.class);
    final String toValue = "4000";
    final boolean includeUpper = true;

    doReturn(toValue).when(currentPart).to();
    doReturn(includeUpper).when(currentPart).includeUpper();

    visitor.mergeQueryParts(previousPart, currentPart);

    verify(visitor).mergeQueryParts(previousPart, currentPart);

    verify(previousPart).to(toValue);
    verify(previousPart).includeUpper(includeUpper);

    verify(currentPart, times(2)).to();
    verify(currentPart).includeUpper();

    verifyNoMoreCollaboration(previousPart, currentPart);
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:27,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例11: testMergeQueryPartsForGreaterThan

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
/**
 * Tests {@link ElasticsearchQueryBuilderVisitor#mergeQueryParts(QueryBuilder, QueryBuilder)} for the case where our
 * current query part is a greater than/greater than or equal to.
 */
@Test
public void testMergeQueryPartsForGreaterThan() throws Exception {
    final RangeQueryBuilder previousPart = mock(RangeQueryBuilder.class);
    final RangeQueryBuilder currentPart = mock(RangeQueryBuilder.class);
    final String fromValue = "4000";
    final boolean includeLower = true;

    doReturn(fromValue).when(currentPart).from();
    doReturn(includeLower).when(currentPart).includeLower();

    visitor.mergeQueryParts(previousPart, currentPart);

    verify(visitor).mergeQueryParts(previousPart, currentPart);

    verify(previousPart).from(fromValue);
    verify(previousPart).includeLower(includeLower);

    verify(currentPart).to();
    verify(currentPart).from();
    verify(currentPart).includeLower();

    verifyNoMoreCollaboration(previousPart, currentPart);
}
 
開發者ID:8x8Cloud,項目名稱:fiql-elasticsearch,代碼行數:28,代碼來源:ElasticsearchQueryBuilderVisitorTest.java

示例12: assertMultipleMetricAggregationWithScriptError

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
@Test
public void assertMultipleMetricAggregationWithScriptError() {
    String indexName = "test1";
    int size = 1;

    Map<String, Integer> termsFactor = new HashMap<String, Integer>();
    termsFactor.put("foo", 1);
    
    buildTestDataset(1, indexName, "type1", size, termsFactor);
    
    SearchResponse searchResponse = client().prepareSearch(indexName)
            .setQuery(matchAllQuery())
            .addAggregation(new MultipleMetricBuilder("metrics")
            		.script(new ScriptBuilder("ratio").script(new Script("value1 / value2")))
            		.field(new SumBuilder("value1").field("value1"))
            		.field(new CountBuilder("value2").field("value2").filter(new RangeQueryBuilder("value1").gt(1000))))
            .execute().actionGet();
    
    MultipleMetric metrics = searchResponse.getAggregations().get("metrics");
    assertEquals(metrics.getValue("value1"), 45.0 * size, 0.0);
    assertEquals(metrics.getValue("value2"), 0.0 * size, 0.0);
    assertEquals(metrics.getValue("ratio"), Double.POSITIVE_INFINITY, 0.0);
    
    assertEquals(metrics.getDocCount("value1"), 10);
    assertEquals(metrics.getDocCount("value2"), 0);
}
 
開發者ID:eliep,項目名稱:elasticsearch-multiple-metric-aggregation,代碼行數:27,代碼來源:MultipleMetricAggregatorTest.java

示例13: assertMultipleMetricAggregationWithFilter

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
@Test
public void assertMultipleMetricAggregationWithFilter() {
    String indexName = "test2";
    int size = 1;

    Map<String, Integer> termsFactor = new HashMap<String, Integer>();
    termsFactor.put("foo", 1);
    
    buildTestDataset(1, indexName, "type1", size, termsFactor);
    
    SearchResponse searchResponse = client().prepareSearch(indexName)
            .setQuery(matchAllQuery())
            .addAggregation(new MultipleMetricBuilder("metrics")
            		.script(new ScriptBuilder("ratio").script(new Script("value1 / value2")))
            		.field(new SumBuilder("value1").field("value1").filter(new RangeQueryBuilder("value1").gt(5)))
            		.field(new CountBuilder("value2").field("value2")))
            .execute().actionGet();
    
    MultipleMetric metrics = searchResponse.getAggregations().get("metrics");
    assertEquals(metrics.getValue("value1"), 30.0 * size, 0.0);
    assertEquals(metrics.getValue("value2"), 10.0 * size, 0.0);
    assertEquals(metrics.getValue("ratio"), metrics.getValue("value1") / metrics.getValue("value2"), 0.0);
    
    assertEquals(metrics.getDocCount("value1"), 4);
    assertEquals(metrics.getDocCount("value2"), 10);
}
 
開發者ID:eliep,項目名稱:elasticsearch-multiple-metric-aggregation,代碼行數:27,代碼來源:MultipleMetricAggregatorTest.java

示例14: assertMultipleMetricAggregationWithUnmappedField

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
@Test
public void assertMultipleMetricAggregationWithUnmappedField() {
    String indexName = "test3";
    int size = 1;

    Map<String, Integer> termsFactor = new HashMap<String, Integer>();
    termsFactor.put("foo", 1);
    
    buildTestDataset(1, indexName, "type1", size, termsFactor);
    
    SearchResponse searchResponse = client().prepareSearch(indexName)
            .setQuery(matchAllQuery())
            .addAggregation(new MultipleMetricBuilder("metrics")
            		.script(new ScriptBuilder("ratio").script(new Script("value1 + value2")))
            		.field(new SumBuilder("value1").field("value4").filter(new RangeQueryBuilder("value1").gt(5)))
            		.field(new CountBuilder("value2").field("value5")))
            .execute().actionGet();
    
    MultipleMetric metrics = searchResponse.getAggregations().get("metrics");
    assertEquals(metrics.getValue("value1"), 0.0, 0.0);
    assertEquals(metrics.getValue("value2"), 0.0, 0.0);
    assertEquals(metrics.getValue("ratio"), metrics.getValue("value1") + metrics.getValue("value2"), 0.0);
    
    assertEquals(metrics.getDocCount("value1"), 0);
    assertEquals(metrics.getDocCount("value2"), 0);
}
 
開發者ID:eliep,項目名稱:elasticsearch-multiple-metric-aggregation,代碼行數:27,代碼來源:MultipleMetricAggregatorTest.java

示例15: adaptRequestBuilder

import org.elasticsearch.index.query.RangeQueryBuilder; //導入依賴的package包/類
@Override
protected SearchRequestBuilder adaptRequestBuilder(final Client esClient,
		final SearchRequestBuilder requestBuilder) {
	QueryBuilder filter = null;
	if (from != null || to != null) {
		final RangeQueryBuilder occRange = QueryBuilders.rangeQuery(Event.FIELD_TIMESTAMP);
		if (from != null) {
			occRange.gte(from.getTime());
		}
		if (to != null) {
			occRange.lte(to.getTime());
		}
		filter = occRange;
	}
	if (filter != null) {
		requestBuilder.setQuery(filter);
	}
	return requestBuilder;
}
 
開發者ID:logsniffer,項目名稱:logsniffer,代碼行數:20,代碼來源:EsEventPersistence.java


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