我正在使用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
}
然后一切正常。
有什么想法吗?