elasticsearch(七)java 搜索功能Search Request的介紹與使用


目錄

1,首先創建主搜索請求:

2,對主搜索請求進行參數設置


       前端幾節都是介紹的基於單個文檔或着單個文檔庫的操作,

       本節開始將介紹基於所有或指定的任何個數文檔庫的操作的api

        SearchRequest用於與搜索文檔、聚合、定制查詢有關的任何操作,還提供了在查詢結果的基於上,對於匹配的關鍵詞進行突出顯示的方法。

1,首先創建搜索請求對象:

SearchRequest searchRequest = new SearchRequest(); 
  
  
 
 
         

2,對搜索請求進行基本參數設置

1)設置查詢指定的某個文檔庫:


   
   
  
  
          
  1. SearchRequest searchRequest = new SearchRequest( "posts");
  2. searchRequest.types( "doc");

2)查詢多個文檔庫,其中多個文檔庫名之間用逗號隔開

 SearchRequest searchRequest = new SearchRequest("posts2","posts", "posts2", "posts1");
  
  
 
 
         

或者這樣設置:


   
   
  
  
          
  1. SearchRequest searchRequest = new SearchRequest();
  2. // 指定只能在哪些文檔庫中查詢:可以添加多個且沒有限制,中間用逗號隔開
  3. searchRequest.indices( "posts2", "posts", "posts2", "posts1");

默認是去所有文檔庫中進行查詢

3)指定查詢的文檔庫中的文檔類型:

searchRequest.types("doc1");
  
  
 
 
         

或多種類型,同樣是文檔類型之間用逗號隔開:

 searchRequest.types("doc1", "doc1", "doc2");
  
  
 
 
         

4)設置指定查詢的路由分片

searchRequest.routing("routing");
  
  
 
 
         

5)用preference方法去指定優先去某個分片上去查詢(默認的是隨機先去某個分片)

searchRequest.preference("_local");
  
  
 
 
         

6)向主搜索請求中可以添加搜索內容的特征參數

a.創建  搜索內容參數設置對象:SearchSourceBuilder

SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
  
  
 
 
         

b. 將SearchSourceBuilder對象添加到搜索請求中:

searchRequest.source(searchSourceBuilder);
  
  
 
 
         

3,為搜索的文檔內容對象SearchSourceBuilder設置參數:

       大多控制搜索內容的行為參數都可以在SearchSourceBuilder上進行設置,SearchSourceBuilder包含與Rest API的搜索請求主體中類似的參數選項。 以下是一些常見選項的幾個示例:

1)查詢包含指定的內容:

a.查詢所有的內容

searchSourceBuilder.query(QueryBuilders.matchAllQuery());
  
  
 
 
         

b.查詢包含關鍵詞字段的文檔:如下,表示查詢出來所有包含user字段且user字段包含kimchy值的文檔

sourceBuilder.query(QueryBuilders.termQuery("user", "kimchy")); 
  
  
 
 
         

c.上面是基於QueryBuilders查詢選項的,另外還可以使用MatchQueryBuilder配置查詢參數


   
   
  
  
          
  1. MatchQueryBuilder matchQueryBuilder = new MatchQueryBuilder( "user", "kimchy");
  2. // 啟動模糊查詢
  3. matchQueryBuilder.fuzziness(Fuzziness.AUTO);
  4. // 在匹配查詢上設置前綴長度選項
  5. matchQueryBuilder.prefixLength( 3);
  6. // 設置最大擴展選項以控制查詢的模糊過程
  7. matchQueryBuilder.maxExpansions( 10);

d.也可以使用QueryBuilders實用程序類創建QueryBuilder對象。此類提供了可用於使用流暢的編程樣式創建QueryBuilder對象的輔助方法:


   
   
  
  
          
  1. QueryBuilder matchQueryBuilder = QueryBuilders.matchQuery( "user", "kimchy")
  2. .fuzziness(Fuzziness. AUTO)
  3. .prefixLength( 3)
  4. .maxExpansions( 10);
注:無論用於創建它的方法是什么,都必須將QueryBuilder對象添加到SearchSourceBuilder
searchSourceBuilder.query(matchQueryBuilder);

3)設置查詢的起始索引位置和數量:如下表示從第1條開始,共返回5條文檔數據


   
   
  
  
          
  1. sourceBuilder .from(0);
  2. sourceBuilder .size(5);

4)設置查詢請求的超時時間:如下表示60秒沒得到返回結果時就認為請求已超時

sourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));
  
  
 
 
         

5)默認情況下,搜索請求會返回文檔_source的內容,但與Rest API中的內容一樣,您可以覆蓋此行為。例如,您可以完全關閉_source檢索:

sourceBuilder.fetchSource(false);
  
  
 
 
         

該方法還接受一個或多個通配符模式的數組,以控制以更精細的方式包含或排除哪些字段


   
   
  
  
          
  1. String[] includeFields = new String[] { "title", "user", "innerObject.*"};
  2. String[] excludeFields = new String[] { "_type"};
  3. sourceBuilder.fetchSource(includeFields, excludeFields);

 

 

本節內容待續,敬請關注 .... 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM