您好,登錄后才能下訂單哦!
ElasticSearch
Elasticsearch是一個基于Lucene的搜索服務(wù)器。它提供了一個分布式多用戶能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java開發(fā)的,并作為Apache許可條款下的開放源碼發(fā)布,是當(dāng)前流行的企業(yè)級搜索引擎。設(shè)計用于云計算中,能夠達到實時搜索,穩(wěn)定,可靠,快速,安裝使用方便。
最近用到ES
查詢,因用的是Java寫的,需要實現(xiàn)一個需求:過濾一部分id,查詢時不需要查出來。
既然需要不包含,那么首先需要實現(xiàn)包含的方式(精確完全匹配),這里我們要用到的是termQuery
首先看下ES Bool
聯(lián)合查詢的屬性:
bool聯(lián)合查詢: must,should,must_not
聯(lián)合查詢就會使用到must
,should
,must_not
三種關(guān)鍵詞。
這三個可以這么理解
具體案例,我需要過濾掉不用的exerciseId
:
BoolQueryBuilder exersiceBoolQuery = QueryBuilders.boolQuery(); if (exersiceIds != null && exersiceIds.size() > 0) { for (String exerciseId: exersiceIds) { exersiceBoolQuery.mustNot(QueryBuilders.termQuery("id", exerciseId)); } }
最后在發(fā)送請求的時候,加上你的exersiceBoolQuery
即可
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。