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


Java SearchHits.getHits方法代碼示例

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


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

示例1: doubleNotTest

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void doubleNotTest() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	SearchHits response1 = query(String.format("SELECT * FROM %s/account WHERE not gender like 'm' and not gender like 'f'", TEST_INDEX));
	Assert.assertEquals(0, response1.getTotalHits());

	SearchHits response2 = query(String.format("SELECT * FROM %s/account WHERE not gender like 'm' and gender not like 'f'", TEST_INDEX));
	Assert.assertEquals(0, response2.getTotalHits());

	SearchHits response3 = query(String.format("SELECT * FROM %s/account WHERE gender not like 'm' and gender not like 'f'", TEST_INDEX));
	Assert.assertEquals(0, response3.getTotalHits());

	SearchHits response4 = query(String.format("SELECT * FROM %s/account WHERE gender like 'm' and not gender like 'f'", TEST_INDEX));
	// assert there are results and they all have gender 'm'
	Assert.assertNotEquals(0, response4.getTotalHits());
	for (SearchHit hit : response4.getHits()) {
		Assert.assertEquals("m", hit.getSource().get("gender").toString().toLowerCase());
	}

	SearchHits response5 = query(String.format("SELECT * FROM %s/account WHERE NOT (gender = 'm' OR gender = 'f')", TEST_INDEX));
	Assert.assertEquals(0, response5.getTotalHits());
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:22,代碼來源:QueryTest.java

示例2: jsonquery

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
/**
 * json查詢
 */
public static void jsonquery() {
    try {
        Settings settings = Settings.settingsBuilder().put("cluster.name", "elasticsearch1").build();
        TransportClient transportClient = TransportClient.builder().
                settings(settings).build().addTransportAddress(
                new InetSocketTransportAddress(InetAddress.getByName("172.16.2.93"), 9300));
        SearchRequestBuilder searchRequestBuilder = transportClient.prepareSearch("service2");
        SearchResponse searchResponse = searchRequestBuilder.setSource("{\n" +
                "\"query\": {\n" +
                "\"bool\": {\n" +
                "\"must\": [\n" +
                "{\n" +
                "\"prefix\": {\n" +
                "\"content\": \"oracle\"\n" +
                "}\n" +
                "}\n" +
                "],\n" +
                "\"must_not\": [ ],\n" +
                "\"should\": [ ]\n" +
                "}\n" +
                "},\n" +
                "\"from\": 0,\n" +
                "\"size\": 10,\n" +
                "\"sort\": [ ],\n" +
                "\"aggs\": { }\n" +
                "}")
                .get();
        SearchHits searchHits = searchResponse.getHits();
        System.out.println();
        System.out.println("Total Hits is " + searchHits.totalHits());
        System.out.println();
        for (int i = 0; i < searchHits.getHits().length; ++i) {
            System.out.println("content is "
                    + searchHits.getHits()[i].getSource().get("content"));
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}
 
開發者ID:Transwarp-DE,項目名稱:Transwarp-Sample-Code,代碼行數:43,代碼來源:SearchES.java

示例3: queryByEsQueryDo

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
public EsResponse queryByEsQueryDo(EsQueryDo esQueryObj) throws EsException {
    validationEsQuery(esQueryObj.getIndexName(),esQueryObj.getTypeName());
    //創建ES查詢Request對象
    SearchRequestBuilder esSearch=buildSearchRequest (esQueryObj);
    //執行查詢
    SearchResponse response =esSearch.execute().actionGet();
    JSONObject resObj = new JSONObject();
    //獲取facet結果
    if(!Check.NuNObject(esQueryObj.aggregationFields())){
        parseAggregationResult(response, esQueryObj.aggregationFields(), resObj);
    }
    //1、獲取搜索的文檔結果
    SearchHits searchHits = response.getHits();
    if (searchHits == null || searchHits.getTotalHits() == 0) {
        return EsResponse.responseOK(null);
    }
    SearchHit[] hits = searchHits.getHits();
    resObj.put("total", searchHits.getTotalHits());
    //1.1、獲取搜索結果
    parseSearchResult(hits, esQueryObj.isHighLigth(), esQueryObj, resObj);
    return EsResponse.responseOK(resObj);
}
 
開發者ID:AsuraTeam,項目名稱:asura,代碼行數:23,代碼來源:EsQuery.java

示例4: complexConditionQuery

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void complexConditionQuery() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
	String errorMessage = "Result does not exist to the condition (gender='m' AND (age> 25 OR account_number>5)) OR (gender='f' AND (age>30 OR account_number < 8)";

	SearchHits response = query(String.format("SELECT * FROM %s/account WHERE (gender='m' AND (age> 25 OR account_number>5)) OR (gender='f' AND (age>30 OR account_number < 8))", TEST_INDEX));
	SearchHit[] hits = response.getHits();

	for(SearchHit hit : hits) {
		Map<String, Object> source = hit.getSource();
		String gender = ((String)source.get("gender")).toLowerCase();
		int age = (int)source.get("age");
		int account_number = (int) source.get("account_number");

		Assert.assertTrue(errorMessage, (gender.equals("m") && (age> 25 || account_number>5)) || (gender.equals("f") && (age>30 || account_number < 8)));
	}
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:17,代碼來源:QueryTest.java

示例5: complexNotConditionQuery

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void complexNotConditionQuery() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	String errorMessage = "Result does not exist to the condition NOT (gender='m' AND NOT (age > 25 OR account_number > 5)) OR (NOT gender='f' AND NOT (age > 30 OR account_number < 8))";

	SearchHits response = query(String.format("SELECT * FROM %s/account WHERE NOT (gender='m' AND NOT (age > 25 OR account_number > 5)) OR (NOT gender='f' AND NOT (age > 30 OR account_number < 8))", TEST_INDEX));
	SearchHit[] hits = response.getHits();

	Assert.assertNotEquals(hits.length, 0);

	for (SearchHit hit : hits) {
		Map<String, Object> source = hit.getSource();
		String gender = ((String) source.get("gender")).toLowerCase();
		int age = (int) source.get("age");
		int account_number = (int) source.get("account_number");

		Assert.assertTrue(errorMessage, !(gender.equals("m") && !(age > 25 || account_number > 5)) || (!gender.equals("f") && !(age > 30 || account_number < 8)));
	}
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:19,代碼來源:QueryTest.java

示例6: likeTest

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void likeTest() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	SearchHits response = query(String.format("SELECT * FROM %s WHERE firstname LIKE 'amb%%' LIMIT 1000", TEST_INDEX));
	SearchHit[] hits = response.getHits();

	// assert the results is correct according to accounts.json data.
	Assert.assertEquals(1, response.getTotalHits());
	Assert.assertEquals("Amber", hits[0].getSource().get("firstname"));
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:10,代碼來源:QueryTest.java

示例7: search

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
/**
 * 查詢
 *
 * @param queryBuilder
 * @param type
 * @param sortField    排序字段
 * @param desc
 * @param from         分頁起始偏移量
 * @param size         頁麵大小
 * @return
 */
private static <T> Pagination<T> search(QueryBuilder queryBuilder, IndexType type, String sortField, boolean desc, int from, int size) {
    List<T> results = new ArrayList<>();
    //不同的索引 變量 代碼通用
    SearchRequestBuilder serachBuilder = EsClientManager.getClient().prepareSearch(esprop.getIndice())
            .setTypes(type.getDataName())
            .setQuery(queryBuilder);
    if (!StringUtils.isEmpty(sortField)) {
        if (sortField.equalsIgnoreCase(SortMode.ORDERVALUE_ASC.getSortField())) {
            serachBuilder.addSort("_score", SortOrder.DESC);
        }
        serachBuilder.addSort(sortField, desc ? SortOrder.DESC : SortOrder.ASC);
    }
    if (0 != size) {
        serachBuilder.setFrom(from).setSize(size);
    }
    SearchResponse response = serachBuilder.execute().actionGet();
    SearchHits searchHits = response.getHits();
    SearchHit[] hits = searchHits.getHits();
    for (SearchHit hit : hits) {
        results.add((T) EsDataUtil.readValue(hit.source(), type.getTypeClass()));
    }
    int total = (int) searchHits.getTotalHits();
    Pagination pagination = new Pagination();
    pagination.setDataList(results);
    pagination.setTotalCount(total);
    return pagination;
}
 
開發者ID:wxz1211,項目名稱:dooo,代碼行數:39,代碼來源:IndexManager.java

示例8: inTermsTestWithStrings

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void inTermsTestWithStrings() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
    SearchHits response = query(String.format("SELECT name FROM %s/gotCharacters WHERE name.firstname = IN_TERMS('daenerys','eddard') LIMIT 1000", TEST_INDEX));
    SearchHit[] hits = response.getHits();
    Assert.assertEquals(2, response.getTotalHits());
    for(SearchHit hit : hits) {
        String firstname =  ((Map<String,Object>) hit.getSource().get("name")).get("firstname").toString();
        assertThat(firstname, isOneOf("Daenerys", "Eddard"));
    }
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:11,代碼來源:QueryTest.java

示例9: notMissFilterSearch

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void notMissFilterSearch() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
	SearchHits response = query(String.format("SELECT * FROM %s/phrase WHERE insert_time2 IS NOT missing", TEST_INDEX));
	SearchHit[] hits = response.getHits();

	// should be 2 according to the data.
	Assert.assertEquals(response.getTotalHits(), 2);
	for(SearchHit hit : hits) {
		assertThat(hit.getSource(), hasKey("insert_time2"));
	}
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:12,代碼來源:QueryTest.java

示例10: betweenTest

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void betweenTest() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	int min = 27;
	int max = 30;
	SearchHits response = query(String.format("SELECT * FROM %s WHERE age BETWEEN %s AND %s LIMIT 1000", TEST_INDEX, min, max));
	SearchHit[] hits = response.getHits();
	for(SearchHit hit : hits) {
		int age = (int) hit.getSource().get("age");
		assertThat(age, allOf(greaterThanOrEqualTo(min), lessThanOrEqualTo(max)));
	}
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:12,代碼來源:QueryTest.java

示例11: inTermsTestWithNumbers

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void inTermsTestWithNumbers() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
    SearchHits response = query(String.format("SELECT name FROM %s/gotCharacters WHERE name.ofHisName = IN_TERMS(4,2) LIMIT 1000", TEST_INDEX));
    SearchHit[] hits = response.getHits();
    Assert.assertEquals(1, response.getTotalHits());
    SearchHit hit = hits[0];
    String firstname =  ((Map<String,Object>) hit.getSource().get("name")).get("firstname").toString();
    Assert.assertEquals("Brandon",firstname);
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:10,代碼來源:QueryTest.java

示例12: orderByDescTest

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void orderByDescTest() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	SearchHits response = query(String.format("SELECT age FROM %s/account ORDER BY age DESC LIMIT 1000", TEST_INDEX));
	SearchHit[] hits = response.getHits();

	ArrayList<Integer> ages = new ArrayList<Integer>();
	for(SearchHit hit : hits) {
		ages.add((int)hit.getSource().get("age"));
	}

	ArrayList<Integer> sortedAges = (ArrayList<Integer>)ages.clone();
	Collections.sort(sortedAges, Collections.reverseOrder());
	Assert.assertTrue("The list is not ordered descending", sortedAges.equals(ages));
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:15,代碼來源:QueryTest.java

示例13: termQueryWithStringLiteral

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void termQueryWithStringLiteral() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
    SearchHits response = query(String.format("SELECT name FROM %s/gotCharacters WHERE name.firstname = term('brandon') LIMIT 1000", TEST_INDEX));
    SearchHit[] hits = response.getHits();
    Assert.assertEquals(1, response.getTotalHits());
    SearchHit hit = hits[0];
    String firstname =  ((Map<String,Object>) hit.getSource().get("name")).get("firstname").toString();
    Assert.assertEquals("Brandon",firstname);
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:10,代碼來源:QueryTest.java

示例14: notInTest

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void notInTest() throws IOException, SqlParseException, SQLFeatureNotSupportedException {
	SearchHits response = query(String.format("SELECT age FROM %s WHERE age NOT IN (20, 22) LIMIT 1000", TEST_INDEX));
	SearchHit[] hits = response.getHits();
	for(SearchHit hit : hits) {
		Map<String, Object> source = hit.getSource();

		// ignore document which not contains the age field.
		if(source.containsKey("age")) {
			int age = (int) source.get("age");
			assertThat(age, not(isOneOf(20, 22)));
		}
	}
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:15,代碼來源:QueryTest.java

示例15: notLikeTests

import org.elasticsearch.search.SearchHits; //導入方法依賴的package包/類
@Test
public void notLikeTests() throws IOException, SqlParseException, SQLFeatureNotSupportedException{
    //cant use string.format cause of %d
    SearchHits response = query("SELECT name FROM " +TEST_INDEX + "/gotCharacters where name.firstname not like '%d' LIMIT 1000");
    Assert.assertEquals(3, response.getTotalHits());
    for(SearchHit hit : response.getHits()) {
        Map<String, Object> sourceAsMap = hit.sourceAsMap();
        String name = ((HashMap<String, Object>) sourceAsMap.get("name")).get("firstname").toString();
        Assert.assertFalse(name+" was in not like %d",name.startsWith("d"));
    }
}
 
開發者ID:mazhou,項目名稱:es-sql,代碼行數:12,代碼來源:QueryTest.java


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