首页 > 解决方案 > 弹性搜索如何索引嵌套列表

问题描述

如何使用列表为嵌套数据结构创建索引?会有其他用户ID的列表,我不知道如何用elasticsearch 6.5索引它们。

UserID -> OtherUserID-> name:"text" , count : "long"

标签: jsonelasticsearch

解决方案


您可以使用嵌套数据类型来创建这样的字段和对象的索引列表。请参考下面的示例并根据您的需要对其进行修改:

映射:

PUT testindex
{
  "mappings": {
    "_doc": {
      "properties": {
        "nestedField": {
          "type": "nested",
          "properties": {
            "field1": {
              "type": "text",
              "fields": {
                "keywords": {
                  "type": "keyword"
                }
              }
            },
            "field2": {
              "type": "integer"
            }
          }
        }
      }
    }
  }
}

添加文档:

对于列表中的单个项目:

PUT testindex/_doc/1
{
  "nestedField": [
    {
      "field1": "Some text",
      "field2": 10
    }
  ]
}

对于列表中的多个项目:

PUT testindex/_doc/2
{
  "nestedField": [
    {
      "field1": "Some other text",
      "field2": 11
    },
    {
      "field1": "random value",
      "field2": 15
    }
  ]
}

推荐阅读