|
47 | 47 | import org.elasticsearch.action.index.IndexRequest;
|
48 | 48 | import org.elasticsearch.action.search.ClearScrollRequest;
|
49 | 49 | import org.elasticsearch.action.search.ClearScrollResponse;
|
| 50 | +import org.elasticsearch.action.search.MultiSearchRequest; |
| 51 | +import org.elasticsearch.action.search.MultiSearchResponse; |
50 | 52 | import org.elasticsearch.action.search.SearchRequest;
|
51 | 53 | import org.elasticsearch.action.search.SearchResponse;
|
52 | 54 | import org.elasticsearch.action.search.SearchScrollRequest;
|
|
127 | 129 | * @author Sascha Woo
|
128 | 130 | * @author Ted Liang
|
129 | 131 | * @author Don Wellington
|
| 132 | + * @author Zetang Zeng |
130 | 133 | */
|
131 | 134 | public class ElasticsearchRestTemplate
|
132 | 135 | implements ElasticsearchOperations, EsClient<RestHighLevelClient>, ApplicationContextAware {
|
@@ -335,6 +338,68 @@ public <T> AggregatedPage<T> queryForPage(SearchQuery query, Class<T> clazz, Sea
|
335 | 338 | return mapper.mapResults(response, clazz, query.getPageable());
|
336 | 339 | }
|
337 | 340 |
|
| 341 | + @Override |
| 342 | + public <T> List<Page<T>> queryForPage(List<SearchQuery> queries, Class<T> clazz) { |
| 343 | + return queryForPage(queries, clazz, resultsMapper); |
| 344 | + } |
| 345 | + |
| 346 | + private <T> List<Page<T>> doMultiSearch(List<SearchQuery> queries, Class<T> clazz, MultiSearchRequest request, SearchResultMapper resultsMapper) { |
| 347 | + MultiSearchResponse.Item[] items = getMultiSearchResult(request); |
| 348 | + List<Page<T>> res = new ArrayList<>(queries.size()); |
| 349 | + int c = 0; |
| 350 | + for (SearchQuery query : queries) { |
| 351 | + res.add(resultsMapper.mapResults(items[c++].getResponse(), clazz, query.getPageable())); |
| 352 | + } |
| 353 | + return res; |
| 354 | + } |
| 355 | + |
| 356 | + private List<Page<?>> doMultiSearch(List<SearchQuery> queries, List<Class<?>> classes, MultiSearchRequest request, SearchResultMapper resultsMapper) { |
| 357 | + MultiSearchResponse.Item[] items = getMultiSearchResult(request); |
| 358 | + List<Page<?>> res = new ArrayList<>(queries.size()); |
| 359 | + int c = 0; |
| 360 | + Iterator<Class<?>> it = classes.iterator(); |
| 361 | + for (SearchQuery query : queries) { |
| 362 | + res.add(resultsMapper.mapResults(items[c++].getResponse(), it.next(), query.getPageable())); |
| 363 | + } |
| 364 | + return res; |
| 365 | + } |
| 366 | + |
| 367 | + private MultiSearchResponse.Item[] getMultiSearchResult(MultiSearchRequest request) { |
| 368 | + MultiSearchResponse response; |
| 369 | + try { |
| 370 | + response = client.multiSearch(request); |
| 371 | + } catch (IOException e) { |
| 372 | + throw new ElasticsearchException("Error for search request: " + request.toString(), e); |
| 373 | + } |
| 374 | + MultiSearchResponse.Item[] items = response.getResponses(); |
| 375 | + Assert.isTrue(items.length == request.requests().size(), "Response should has same length with queries"); |
| 376 | + return items; |
| 377 | + } |
| 378 | + |
| 379 | + @Override |
| 380 | + public <T> List<Page<T>> queryForPage(List<SearchQuery> queries, Class<T> clazz, SearchResultMapper mapper) { |
| 381 | + MultiSearchRequest request = new MultiSearchRequest(); |
| 382 | + for (SearchQuery query : queries) { |
| 383 | + request.add(prepareSearch(prepareSearch(query, clazz), query)); |
| 384 | + } |
| 385 | + return doMultiSearch(queries, clazz, request, mapper); |
| 386 | + } |
| 387 | + |
| 388 | + @Override |
| 389 | + public List<Page<?>> queryForPage(List<SearchQuery> queries, List<Class<?>> classes) { |
| 390 | + return queryForPage(queries, classes, resultsMapper); |
| 391 | + } |
| 392 | + |
| 393 | + @Override |
| 394 | + public List<Page<?>> queryForPage(List<SearchQuery> queries, List<Class<?>> classes, SearchResultMapper mapper) { |
| 395 | + MultiSearchRequest request = new MultiSearchRequest(); |
| 396 | + Iterator<Class<?>> it = classes.iterator(); |
| 397 | + for (SearchQuery query : queries) { |
| 398 | + request.add(prepareSearch(prepareSearch(query, it.next()), query)); |
| 399 | + } |
| 400 | + return doMultiSearch(queries, classes, request, mapper); |
| 401 | + } |
| 402 | + |
338 | 403 | @Override
|
339 | 404 | public <T> T query(SearchQuery query, ResultsExtractor<T> resultsExtractor) {
|
340 | 405 | SearchResponse response = doSearch(prepareSearch(query, Optional.ofNullable(query.getQuery())), query);
|
@@ -1026,6 +1091,16 @@ public <T> Page<T> moreLikeThis(MoreLikeThisQuery query, Class<T> clazz) {
|
1026 | 1091 | }
|
1027 | 1092 |
|
1028 | 1093 | private SearchResponse doSearch(SearchRequest searchRequest, SearchQuery searchQuery) {
|
| 1094 | + prepareSearch(searchRequest, searchQuery); |
| 1095 | + |
| 1096 | + try { |
| 1097 | + return client.search(searchRequest); |
| 1098 | + } catch (IOException e) { |
| 1099 | + throw new ElasticsearchException("Error for search request with scroll: " + searchRequest.toString(), e); |
| 1100 | + } |
| 1101 | + } |
| 1102 | + |
| 1103 | + private SearchRequest prepareSearch(SearchRequest searchRequest, SearchQuery searchQuery) { |
1029 | 1104 | if (searchQuery.getFilter() != null) {
|
1030 | 1105 | searchRequest.source().postFilter(searchQuery.getFilter());
|
1031 | 1106 | }
|
@@ -1074,12 +1149,7 @@ private SearchResponse doSearch(SearchRequest searchRequest, SearchQuery searchQ
|
1074 | 1149 | searchRequest.source().aggregation(aggregatedFacet.getFacet());
|
1075 | 1150 | }
|
1076 | 1151 | }
|
1077 |
| - |
1078 |
| - try { |
1079 |
| - return client.search(searchRequest); |
1080 |
| - } catch (IOException e) { |
1081 |
| - throw new ElasticsearchException("Error for search request with scroll: " + searchRequest.toString(), e); |
1082 |
| - } |
| 1152 | + return searchRequest; |
1083 | 1153 | }
|
1084 | 1154 |
|
1085 | 1155 | private SearchResponse getSearchResponse(ActionFuture<SearchResponse> response) {
|
|
0 commit comments