作為新人的我,在使用的elasticsearch 時,常遇到一些問題,而今天遇到的問題就是:在使用elasticsearch 搜索中文時,無返回結果?
問題描述如下:
1.在kibana 上查看日志的內容是可以用中文進行搜索的,如下圖所示:
然而,在我的代碼里用中文進行查詢時,卻只會返回空,查詢時使用的代碼如下:
/** * 執行搜索 * * @param queryBuilder * @param indexname * @param type * @return */ public void searcher(QueryBuilder queryBuilder, String indexname,String type) { SearchRequestBuilder srbuilder = client.prepareSearch(indexname) .setTypes(type) .setQuery(queryBuilder) .addHighlightedField("*") .setHighlighterRequireFieldMatch(false) .setFrom(0) .setSize(1000) .setExplain(true); SearchResponse searchResponse = srbuilder.execute().actionGet(); //打印查詢體 System.out.println("--->"+srbuilder.toString()); //打印返回結果 System.out.println(">>>>"+searchResponse.toString()); SearchHits hits = searchResponse.getHits(); System.out.println("查詢到記錄數=" + hits.getTotalHits()); } public static void main(String[] args) throws IOException { ElasticSearchHandler esHandler = new ElasticSearchHandler(); // 查詢條件 String type = "system"; String indexname = "logstash-2016-06-11"; QueryBuilder queryBuilder = QueryBuilders.termQuery("message", "測試"); BoolQueryBuilder bool = QueryBuilders.boolQuery(); bool.must(queryBuilder); esHandler.searcher(bool, indexname,type); }
查詢體:
返回的結果:
到底是啥原因呢?在網上找了很久都沒有結果,只能靠自己摸索了,終於在樓主的幾經艱苦之下找到了問題原因。
問題原因其實很簡單:elasticsearch 里默認的IK分詞器是會將每一個中文都進行了分詞的切割,所以你直接想查一整個詞,或者一整句話是無返回結果的。
找了到原因,那解決辦法就簡單了,只需要在查詢時,先把你要查詢的內容切分成一個一個的字分別構成查詢體,再組合在一起即可,如下所示。
public static void main(String[] args) throws IOException { ElasticSearchHandler esHandler = new ElasticSearchHandler(); // 查詢條件 String type = "system"; String indexname = "logstash-2016-06-11"; QueryBuilder queryBuilder = QueryBuilders.termQuery("message", "測"); QueryBuilder queryBuilder2 = QueryBuilders.termQuery("message", "試"); BoolQueryBuilder bool = QueryBuilders.boolQuery(); bool.must(queryBuilder); bool.must(queryBuilder2); esHandler.searcher(bool, indexname,type); }
這一次的查詢體:
查詢結果:
如果有更多,更好的解決方法,歡迎大家在評論區一起交流交流,謝謝。