溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JAVA使用ElasticSearch查詢in和not in的實現(xiàn)方式

發(fā)布時間:2020-08-22 16:03:11 來源:腳本之家 閱讀:963 作者:執(zhí)筆記憶的空白 欄目:編程語言

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)鍵詞。

這三個可以這么理解

  • must: 文檔必須完全匹配條件
  • should: should下面會帶一個以上的條件,至少滿足一個條件,這個文檔就符合should
  • must_not: 文檔必須不匹配條件

具體案例,我需要過濾掉不用的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)鏈接

向AI問一下細(xì)節(jié)

免責(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)容。

AI