摘要:一使用進行匹配的時候匹配的時候,如果想盡可能的多檢索結果,考慮使用如果想盡可能精確的匹配分詞結果,考慮使用如果短語匹配的時候,怕遺漏,考慮使用。
一、使用match進行匹配的時候:
1.匹配的時候,如果想盡可能的多檢索結果,考慮使用match;
2.如果想盡可能精確的匹配分詞結果,考慮使用match_phrase;
3.如果短語匹配的時候,怕遺漏,考慮使用match_phrase_prefix。
private static void addKeywordSearchQuery(String keyWordStr,BoolQueryBuilder boolQueryBuilder){ String[] keywords = keyWordStr.split("|"); //這里注意must必須為平級,否則會合并 BoolQueryBuilder shouldBool = QueryBuilders.boolQuery(); for (int i = 0; i < keywords.length; i++) { if (StringUtils.isNotEmpty(keywords[i])) { String[] split = keywords[i].split("+| "); if (split.length>1){ BoolQueryBuilder contetnQuery = QueryBuilders.boolQuery(); BoolQueryBuilder titleQuery = QueryBuilders.boolQuery(); for (int j = 0; j < split.length; j++) { if (!StringUtils.isEmpty(split[j])){ contetnQuery.must(QueryBuilders.matchPhrasePrefixQuery("content",split[j])); titleQuery.must(QueryBuilders.matchPhrasePrefixQuery("title",split[j])); } } shouldBool.should(QueryBuilders.boolQuery().should(contetnQuery).should(titleQuery)); }else { BoolQueryBuilder contentShould = QueryBuilders.boolQuery(); contentShould.should(QueryBuilders.matchPhrasePrefixQuery("content", keywords[i])); contentShould.should(QueryBuilders.matchPhrasePrefixQuery("title", keywords[i])); shouldBool.should(contentShould); } } } boolQueryBuilder.must( QueryBuilders.boolQuery().must(shouldBool)); }四、可以使用range來確定范圍,時間上比較常用:
boolQueryBuilder.must(QueryBuilders.rangeQuery("infotime").gte(opinionSearchBean.getStartTime().getTime()) .lte(opinionSearchBean.getEndTime().getTime()));五、對id進行過濾
boolQueryBuilder.filter(QueryBuilders.idsQuery().types("opiniondata") .addIds(opinionids.toArray(new String[opinionids.size()])));六、對某個值進行排序的時候,如果沒有設置默認值,則這個值初始化是null,這時候排序則部分生效,如果需要對某個值進行排序的時候,需要進行初始值設置即可。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/69387.html
摘要:另外集群也沒有做物理隔離,有一次促銷活動就因為粉絲數據量過于龐大導致進程內存耗盡而,使得集群內全部索引都無法正常工作,這給我上了深深的一課。 有贊搜索平臺是一個面向公司內部各項搜索應用以及部分 NoSQL 存儲應用的 PaaS 產品,幫助應用合理高效的支持檢索和多維過濾功能,有贊搜索平臺目前支持了大大小小一百多個檢索業務,服務于近百億數據。 在為傳統的搜索應用提供高級檢索和大數據交互能...
摘要:基本概念在深入解讀之前,先了解下的幾個基本概念,以及這幾個概念背后隱藏的一些東西。如圖是一個內的基本組成,內數據只是一個抽象表示,不代表其內部真實數據結構。即詞典,是根據條件查找的基本索引。 前言 Apache Lucene是一個開源的高性能、可擴展的信息檢索引擎,提供了強大的數據檢索能力。Lucene已經發展了很多年,其功能越來越強大,架構也越來越精細。它目前不僅僅能支持全文索引,也...
摘要:基本概念在深入解讀之前,先了解下的幾個基本概念,以及這幾個概念背后隱藏的一些東西。如圖是一個內的基本組成,內數據只是一個抽象表示,不代表其內部真實數據結構。即詞典,是根據條件查找的基本索引。 前言 Apache Lucene是一個開源的高性能、可擴展的信息檢索引擎,提供了強大的數據檢索能力。Lucene已經發展了很多年,其功能越來越強大,架構也越來越精細。它目前不僅僅能支持全文索引,也...
閱讀 3069·2021-09-28 09:43
閱讀 902·2021-09-08 09:35
閱讀 1441·2019-08-30 15:56
閱讀 1183·2019-08-30 13:00
閱讀 2732·2019-08-29 18:35
閱讀 1829·2019-08-29 14:07
閱讀 3432·2019-08-29 13:13
閱讀 1333·2019-08-29 12:40