我正在使用 ElasticSearch 来索引文档。
我的映射是:
"mongodocid": {
"boost": 1.0,
"store": "yes",
"type": "string"
},
"fulltext": {
"boost": 1.0,
"index": "analyzed",
"store": "yes",
"type": "string",
"term_vector": "with_positions_offsets"
}
为了突出显示完整的全文,我设置number_of_framgments
为 0。
如果我执行以下类似 Lucene 的字符串查询:
{
"highlight": {
"pre_tags": "<b>",
"fields": {
"fulltext": {
"number_of_fragments": 0
}
},
"post_tags": "</b>"
},
"query": {
"query_string": {
"query": "fulltext:test"
}
},
"size": 100
}
对于结果集中的某些文档,突出显示的全文的长度小于全文本身。由于我设置number_of_fragments
为 0 和pre_tags
/post_tags
被添加,这不应该发生。
现在出现了奇怪的行为:如果我只通过这样做来搜索失败的元素之一:
{
"highlight": {
"pre_tags": "<b>",
"fields": {
"fulltext": {
"number_of_fragments": 0
}
},
"post_tags": "</b>"
},
"query": {
"query_string": {
"query": "fulltext:test AND mongodocid:4d0a861c2ebef6032c00b1ec"
}
},
"size": 100
}
然后一切正常。
有任何想法吗?