1、Multi-Search多搜索请求

Multi-Search可同时添加多个search搜索请求,并行地在一个http请求中执行多个搜索请求,相较多次单请求查询可提升查询效率。ES客户掉通过mget方法实现多请求搜索:

public void multiSearch(){
RestHighLevelClient client = elasticClient.getRestHighLevelClient();
MultiSearchRequest request = new MultiSearchRequest();
SearchRequest firstSearchRequest = new SearchRequest();
SearchSourceBuilder firstBuilder = new SearchSourceBuilder();
firstBuilder.query(matchQuery("name","潇潇"));
firstSearchRequest.source(firstBuilder);
request.add(firstSearchRequest);
SearchRequest secondRequest = new SearchRequest();
SearchSourceBuilder secondBuild = new SearchSourceBuilder();
secondBuild.query(matchQuery("position","建筑师"));
secondRequest.source(secondBuild);
request.add(secondRequest);
try {
MultiSearchResponse multiResponse = client.msearch(request, RequestOptions.DEFAULT);
MultiSearchResponse.Item firstItem = multiResponse.getResponses()[0];
if (firstItem.getFailure() != null) {
System.out.println("第一个请求失败!");
}
SearchResponse firstResponse = firstItem.getResponse();
for (SearchHit documentFields : firstResponse.getHits().getHits()) {
System.out.println("第一个查询请求返回:"+documentFields.getSourceAsString());
}
MultiSearchResponse.Item seconditem = multiResponse.getResponses()[1];
if (seconditem.getFailure() != null) {
System.out.println("第二个请求失败!");
}
SearchResponse secondResponse = seconditem.getResponse();
for (SearchHit documentFields : secondResponse.getHits().getHits()) {
System.out.println("第二的查询请求返回:" + documentFields.getSourceAsString());
}
client.close();
} catch (Exception e) {
e.printStackTrace();
}
}

模板搜索

最新文章

  1. MySQL数据表操作
  2. .deb文件打包
  3. tuning-primer.sh mysql 报表
  4. Docker学习总结之docker入门
  5. LeetCode题解——Container With Most Water
  6. C#中 多线程执行含有返回值的函数
  7. UVA10090 数论基础 exgcd
  8. oracle开启/关闭归档模式
  9. TypeScript 5 Angular 2
  10. POJ3264/RMQ
  11. BroadcastReceiver的两种注册方式之------动态注册
  12. linux下zookeeper 配置参数
  13. 九度OJ题目1003:A+B
  14. 初识Asp.Net WebApi
  15. python 上传百度语音识别+文字返回结果
  16. Tpcc-MySQL对mysql数据库进行性能测试报告、分析及使用gnuplot生成图表展示
  17. Maximum Size Subarray Sum Equals k LT325
  18. es-06-java创建mapping和setting
  19. prometheus如何使用blackbox-exporter来获取k8s的网络性能
  20. 一文总结之Redis

热门文章

  1. vi 编辑器的复制
  2. C++之Vect
  3. Gym 100971D Laying Cables 二分 || 单调栈
  4. 寻找jar包的方法
  5. WPF OnApplyTemplate 不执行 或者执行滞后的疑惑
  6. 介绍一个很好用的Rsa加解密的.Net库 Kalix.ApiCrypto
  7. JAVA爬虫---验证码识别技术(一)
  8. Miner3D Professional专业版
  9. vue组件总结(三)
  10. wordpress中一些喜欢的主题