Elasticsearch查詢之Term?Query示例解析
Term Query
Term Query是一種最基本的查詢方式,它用于在Elasticsearch中查詢一個字段中包含指定關(guān)鍵詞的文檔,與MySQL中的等值查詢類似。使用Term Query時,可以對字段進(jìn)行完全匹配,且區(qū)分大小寫。
基本語法
GET /{index}/_search { "query": { "term": { "{field}": "{value}" } } }
其中,{index}表示查詢的索引名稱,{field}表示需要查詢的字段,{value}表示需要匹配的值。
Java代碼寫法
// TODO 省略導(dǎo)入包 import java.io.IOException; public class TermQueryExample { public static void main(String[] args) throws IOException { RestHighLevelClient client = new RestHighLevelClient( RestClient.builder( new HttpHost("localhost", 9200, "http"))); SearchRequest searchRequest = new SearchRequest("my_index"); // 這里的searchSourceBuilder 相當(dāng)于 query:{} SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); // query:{term:{"field_name":"field_value"}} searchSourceBuilder.query(QueryBuilders.termQuery("field_name", "field_value")); searchSourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS)); searchRequest.source(searchSourceBuilder); // 執(zhí)行查詢 SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); // TODO: 解析搜索結(jié)果 client.close(); } }
Terms-匹配多個值
term查詢只能用于匹配該屬性的單個值,若想匹配多個值,可以用terms查詢
基本語法
GET /{index}/_search { "query": { "terms": { "{field}": [ "{value1}", "{value2}", "{value3}" ] } } }
Java寫法
SearchRequest searchRequest = new SearchRequest("index"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); // 注意這里是使用termsQuery("field",value1,value2) TermsQueryBuilder termsQueryBuilder = QueryBuilders.termsQuery("field", "value1", "value2", "value3"); searchSourceBuilder.query(termsQueryBuilder); searchRequest.source(searchSourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
Term查詢可配置的其他參數(shù)
Term Query還有其他的一些設(shè)置參數(shù),比如:
- boost參數(shù):可以為查詢結(jié)果設(shè)置權(quán)重,提高或降低查詢結(jié)果的得分,影響查詢結(jié)果的排名。
- case_insensitive參數(shù):設(shè)置是否對查詢進(jìn)行大小寫不敏感的匹配。
- rewrite參數(shù):控制查詢的rewrite策略,主要用于控制查詢性能,緩存占用等方面。
- index參數(shù):控制是否在查詢時使用倒排索引,以及使用哪些倒排索引進(jìn)行查詢。
總結(jié)
使用Term Query時需要注意以下幾點:
- 僅匹配完全匹配的關(guān)鍵字。
- 字段必須是不分詞的。
- 通常情況下,不需要將關(guān)鍵字轉(zhuǎn)換為小寫字母,因為Term Query不會將關(guān)鍵字轉(zhuǎn)換為小寫字母。
總之,Term Query非常適合用于對某個字段進(jìn)行精確匹配的場景。如果您想進(jìn)行模糊匹配或全文搜索,請考慮使用Match Query。
以上就是Elasticsearch查詢之Term Query示例解析的詳細(xì)內(nèi)容,更多關(guān)于Elasticsearch Term查詢的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java Servlet簡單實例分享(文件上傳下載demo)
下面小編就為大家?guī)硪黄狫ava Servlet簡單實例分享(文件上傳下載demo)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05詳解SpringBoot中異步請求的實現(xiàn)與并行執(zhí)行
這篇文章主要為大家詳細(xì)介紹了在SpringBoot中如何是實現(xiàn)異步請求、并行執(zhí)行,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02關(guān)于springboot2整合lettuce啟動卡住問題的解決方法
Lettuce和Jedis的都是連接Redis Server的客戶端程序,下面這篇文章主要給大家介紹了關(guān)于springboot2整合lettuce啟動卡住問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12詳解Spring Cloud Finchley版中Consul多實例注冊的問題處理
這篇文章主要介紹了詳解Spring Cloud Finchley版中Consul多實例注冊的問題處理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08SpringAOP實現(xiàn)自定義接口權(quán)限控制
本文主要介紹了SpringAOP實現(xiàn)自定義接口權(quán)限控制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11springboot @WebFilter注解過濾器的實現(xiàn)
這篇文章主要介紹了springboot @WebFilter注解過濾器的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03