背景:ElasticSearch中要查询两个字段,一个字段不要分词的精确查询,在这边就想到了TermsQuery,但是无论干嘛都无果,包括把该字段设为了keyword类型。
后来放弃使用TermsQuery,使用了MatchPhraseQuery。
.must(new MatchPhraseQueryBuilder("eventType", type)))
后期才知道这是短语匹配,总感觉怪的一p。
实际上,还是keyword的问题。虽然定义字符串说text是分词的,keyword是不分词的。但是该字段还是会被分词,如果分词的索引库不包含该字段的完整词,那么直接对该字段用TermsQuery是完全无法查询的。
从一开始
.must(new TermQueryBuilder("eventType",type)))
改成这样既可以了
.must(new TermQueryBuilder("eventType.keyword",type)))
.keyword这样才是真正意义上的不分词处理字段。
mysql多表查询是真的香,立志想做一个DBA,拼搏百天。