search.asciidoc 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. [[search]]
  2. == Search API
  3. The search API allows one to execute a search query and get back search hits
  4. that match the query. It can be executed across one or more indices and
  5. across one or more types. The query can either be provided using the
  6. <<query-dsl-queries,query Java API>> or
  7. the <<query-dsl-filters,filter Java API>>.
  8. The body of the search request is built using the
  9. `SearchSourceBuilder`. Here is an example:
  10. [source,java]
  11. --------------------------------------------------
  12. import org.elasticsearch.action.search.SearchResponse;
  13. import org.elasticsearch.action.search.SearchType;
  14. import org.elasticsearch.index.query.FilterBuilders.*;
  15. import org.elasticsearch.index.query.QueryBuilders.*;
  16. --------------------------------------------------
  17. [source,java]
  18. --------------------------------------------------
  19. SearchResponse response = client.prepareSearch("index1", "index2")
  20. .setTypes("type1", "type2")
  21. .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
  22. .setQuery(QueryBuilders.termQuery("multi", "test")) // Query
  23. .setPostFilter(FilterBuilders.rangeFilter("age").from(12).to(18)) // Filter
  24. .setFrom(0).setSize(60).setExplain(true)
  25. .execute()
  26. .actionGet();
  27. --------------------------------------------------
  28. Note that all parameters are optional. Here is the smallest search call
  29. you can write:
  30. [source,java]
  31. --------------------------------------------------
  32. // MatchAll on the whole cluster with all default options
  33. SearchResponse response = client.prepareSearch().execute().actionGet();
  34. --------------------------------------------------
  35. NOTE: Although the Java API defines the additional search types QUERY_AND_FETCH and
  36. DFS_QUERY_AND_FETCH, these modes are internal optimizations and should not
  37. be specified explicitly by users of the API.
  38. For more information on the search operation, check out the REST
  39. {ref}/search.html[search] docs.
  40. [[scrolling]]
  41. === Using scrolls in Java
  42. Read the {ref}/search-request-scroll.html[scroll documentation]
  43. first!
  44. [source,java]
  45. --------------------------------------------------
  46. import static org.elasticsearch.index.query.FilterBuilders.*;
  47. import static org.elasticsearch.index.query.QueryBuilders.*;
  48. QueryBuilder qb = termQuery("multi", "test");
  49. SearchResponse scrollResp = client.prepareSearch(test)
  50. .setSearchType(SearchType.SCAN)
  51. .setScroll(new TimeValue(60000))
  52. .setQuery(qb)
  53. .setSize(100).execute().actionGet(); //100 hits per shard will be returned for each scroll
  54. //Scroll until no hits are returned
  55. while (true) {
  56. for (SearchHit hit : scrollResp.getHits().getHits()) {
  57. //Handle the hit...
  58. }
  59. scrollResp = client.prepareSearchScroll(scrollResp.getScrollId()).setScroll(new TimeValue(600000)).execute().actionGet();
  60. //Break condition: No hits are returned
  61. if (scrollResp.getHits().getHits().length == 0) {
  62. break;
  63. }
  64. }
  65. --------------------------------------------------
  66. [[msearch]]
  67. === MultiSearch API
  68. See {ref}/search-multi-search.html[MultiSearch API Query]
  69. documentation
  70. [source,java]
  71. --------------------------------------------------
  72. SearchRequestBuilder srb1 = node.client()
  73. .prepareSearch().setQuery(QueryBuilders.queryString("elasticsearch")).setSize(1);
  74. SearchRequestBuilder srb2 = node.client()
  75. .prepareSearch().setQuery(QueryBuilders.matchQuery("name", "kimchy")).setSize(1);
  76. MultiSearchResponse sr = node.client().prepareMultiSearch()
  77. .add(srb1)
  78. .add(srb2)
  79. .execute().actionGet();
  80. // You will get all individual responses from MultiSearchResponse#getResponses()
  81. long nbHits = 0;
  82. for (MultiSearchResponse.Item item : sr.getResponses()) {
  83. SearchResponse response = item.getResponse();
  84. nbHits += response.getHits().getTotalHits();
  85. }
  86. --------------------------------------------------
  87. [[java-search-aggs]]
  88. === Using Aggregations
  89. The following code shows how to add two aggregations within your search:
  90. [source,java]
  91. --------------------------------------------------
  92. SearchResponse sr = node.client().prepareSearch()
  93. .setQuery(QueryBuilders.matchAllQuery())
  94. .addAggregation(
  95. AggregationBuilders.terms("agg1").field("field")
  96. )
  97. .addAggregation(
  98. AggregationBuilders.dateHistogram("agg2")
  99. .field("birth")
  100. .interval(DateHistogram.Interval.YEAR)
  101. )
  102. .execute().actionGet();
  103. // Get your facet results
  104. Terms agg1 = sr.getAggregations().get("agg1");
  105. DateHistogram agg2 = sr.getAggregations().get("agg2");
  106. --------------------------------------------------
  107. See <<java-aggs,Aggregations Java API>>
  108. documentation for details.
  109. [[java-search-template]]
  110. === Using Search Templates
  111. See {ref}/search-template.html[Search Template] documentation
  112. Define your template parameters as a `Map<String,Object>`:
  113. [source,java]
  114. --------------------------------------------------
  115. Map<String, Object> template_params = new HashMap<>();
  116. template_params.put("param_gender", "male");
  117. --------------------------------------------------
  118. You can use your stored search templates in `config/scripts`.
  119. For example, if you have a file named `config/scripts/template_gender.mustache` containing:
  120. [source,js]
  121. --------------------------------------------------
  122. {
  123. "template" : {
  124. "query" : {
  125. "match" : {
  126. "gender" : "{{param_gender}}"
  127. }
  128. }
  129. }
  130. }
  131. --------------------------------------------------
  132. Execute it with:
  133. [source,java]
  134. --------------------------------------------------
  135. SearchResponse sr = client.prepareSearch()
  136. .setTemplateName("template_gender")
  137. .setTemplateType(ScriptService.ScriptType.FILE)
  138. .setTemplateParams(template_params)
  139. .get();
  140. --------------------------------------------------
  141. You can also store your template in a special index named `.scripts`:
  142. [source,java]
  143. --------------------------------------------------
  144. client.preparePutIndexedScript("mustache", "template_gender",
  145. "{\n" +
  146. " \"template\" : {\n" +
  147. " \"query\" : {\n" +
  148. " \"match\" : {\n" +
  149. " \"gender\" : \"{{param_gender}}\"\n" +
  150. " }\n" +
  151. " }\n" +
  152. " }\n" +
  153. "}").get();
  154. --------------------------------------------------
  155. To execute an indexed templates, use `ScriptService.ScriptType.INDEXED`:
  156. [source,java]
  157. --------------------------------------------------
  158. SearchResponse sr = client.prepareSearch()
  159. .setTemplateName("template_gender")
  160. .setTemplateType(ScriptService.ScriptType.INDEXED)
  161. .setTemplateParams(template_params)
  162. .get();
  163. --------------------------------------------------