使用es的query string方式检索遇到的问题:
场景:
有一个索引:
test_index
多个type:
one_type,two_type
这两个type之中都有一个my_field的字段,其中one_type中的my_field,使用mmseg分词,而two_type不分词
大致mapping结构如下:
"one_type":{
"properties":{
"my_field":{
"type":"string",
"analyzer":"mmseg"
}
}
}
"one_type":{
"properties":{
"my_field":{
"type":"string",
"index":"not_analyzer"
}
}
}
如果使用类似的查询语句检索test索引中的文档,可能导致无法找到结果:
{
"from": 0,
"size": 25,
"query": {
"bool": {
"must": [
{
"query_string": {
"query": "综合性期刊",
"fields": [
"my_field"
],
"default_operator": "and"
}
}
]
}
}
}
我猜测原因大概如下:
query string方式采用的分词方式为字段之中指定的分词方式,上面的情况,如果只看字段名my_field,那么该字段有两种分词方式,分别是one_type指定的mmseg和two_type中指定的not_analyzer,此时,如果不指定使用的是哪个类型,那么es就无法弄清楚到底使用哪种分词方式(推测可能采用了一种非我们所愿意的方式),因此导致无法检索出结果。
有如下解决方式:
1、在mapping定义是采用不同的字段名
2、在检索时,加上类型名3、如果是相同的字段名,都采用相同的分词方式