【发布时间】:2010-12-22 18:58:04
【问题描述】:
我正在使用 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
}
然后一切正常。
有什么想法吗?
【问题讨论】:
标签: lucene elasticsearch