弹性搜索:使用通配符映射属性类型作为属性名称


Elastic search: map property types using wildcard for property name

我想将映射应用于所有属性。我可以在不命名属性的情况下这样做吗?

例如

'body' => [
    'doc_type' =>
        'properties' =>
            'networks' =>
                'properties' => [
                    '*' => ['type' => 'integer']
                ]
            ]
        ]
    ]
]

而不是:

'properties' => [
    'vip10415' => ['type' => 'integer'],
    'vip86485' => ['type' => 'integer'],
    'vip23465' => ['type' => 'integer'],
    'vip97949' => ['type' => 'integer']
    ....
 ]

我想这样做的原因是,直到运行时才知道将使用哪些属性。

我知道查询可以有通配符,但还没有看到映射是否可以。我查看了动态映射,但它不是这样工作的。

更新:

我尝试插入整数并让弹性推断它们的类型,但它将它们解析为类型"long"。我使用 php 插入并确保它们是带有 intval() 函数的整数。

更新:

"属性"

实际上是嵌套属性"网络"的子字段。要存储为 int 的属性的名称要到运行时才能知道。

更新:

我尝试应用@bittusarkar在doc_type中推荐的动态映射模板,但它引发了无法解析映射异常。

"dynamic_templates" => [
    "integers" => [
        "match_mapping_type" => "long",
        "mapping" => [
            "type" => "integer"
        ]
    ]
]

如果这些字段实际上是整数类型,则甚至不需要在映射中显式定义它们。只需有一个空映射并开始使用这些字段为文档编制索引。Elasticsearch可以推断字段的类型并动态更新映射。您所要求的也可以通过动态模板来实现,但 IMO 那将是矫枉过正。

由于您希望integer类型而不是默认long,因此动态模板就是答案。请参阅下面的映射定义。它会将检测到类型为 long 的任何字段的类型转换为 integer 类型。

{
    "mappings": {
        "mapping_name": {
            "dynamic_templates": [
                {
                    "convertToInteger": {
                        "match_mapping_type": "long",
                        "mapping": {
                            "type": "integer"
                        }
                    }
                }
            ]
        }
    }
}

USe Dynamic Templates

PUT /my_index
{
 "mappings": {
  "my_type": {
     "dynamic_templates": [
        {
           "analysed_string_template": {
              "match": "*",
              "mapping": {
                 "type": "integer"
              }
             }
          }
        ]
     }
    }
 }

在这里学习更多