zoukankan      html  css  js  c++  java
  • Elasticsearch 映射类型之数组类型(arrays)

    在Elasticsearch中,没有专用的array数据类型。默认情况下,任何字段都可以包含零个或多个值,但是,数组中的所有值都必须具有相同的数据类型

    这一点是区别于nested的,nested指的对象的集合。而arrays则是单一类型的数组集合而已。

    此外,不需要专门的类型类定义数组类型。

    例如:

    • 字符串数组 ["one", "two"]
    • 整数数组 [ 1,2]
    • 数组的数组:[ 1[ 2,3]],这是相当于[ 1,2,3]

    动态添加字段时,数组中的第一个值确定field type。所有后续值必须具有相同的数据类型,或者至少必须能够将后续值强制转换为相同的数据类型。像[1, 3, "some word"] 不支持混合使用。

    数组类型映射建立示例如下。

    PUT example
    PUT example/docs/_mapping
    {
        "properties": {
            "id":{"type": "long"},
            "name": {"type": "text"},
            "age":{"type":"integer"},
            "hobby": {"type": "text"}
        }
    }

    注意:数组字段的定义,不是array哦。

    数组类型的对象添加示例如下。

    PUT example/docs/1 
    {
        "id": 111,
        "name":"张三",
        "age":22,
        "hobby":["篮球","摔跤"]
    }
    PUT example/docs/2 
    {
        "id": 222,
        "name":"张三2",
        "age":21,
        "hobby":["篮球222","摔跤222"]
    }

    数组类型的搜索示例如下。

    #搜索爱好有篮球的
    GET example/docs/_search
    {
        "query": {
            "match": {
                "hobby": "篮球"
            }
        }
    }
    # 最后搜出来2个结果
    
    
    GET example/docs/_search
    {
        "query": {
            "match": {
                "hobby": "22"
            }
        }
    }
    # 最后搜出来1个结果
  • 相关阅读:
    程序崩溃访问非法内存
    C# IP转换,时间转换
    _heap_alloc_dbg 崩溃
    TaskIcon 系统任务栏图标
    zlib 压缩使用
    桌面清理工具
    CMMI知识库(精简版)
    JAVA程序员面试题集合
    OracleDECODE用法
    Oracle索引重建
  • 原文地址:https://www.cnblogs.com/chong-zuo3322/p/13879960.html
Copyright © 2011-2022 走看看