6

我正在使用 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
}

然后一切正常。

有任何想法吗?

4

1 回答 1

6

听起来像是 0.14.0 中已修复的问题(请参阅#479)。写的时候0.14.0还没有发布,可以试试master吗?

于 2010-12-22T20:37:10.263 回答