• 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个结果
  • 相关阅读:
    Docker安装IBM MQ
    Spark On Yarn搭建及各运行模式说明
    Hadoop2.0之YARN组件
    HBase记录
    Spark对接Kafka、HBase
    SparkStreaming个人记录
    Java解决异常之try、catch、finally、throw、throws&log4j记录日志步骤
    Java访问权限修饰符public protected friendly private用法总结(转载好文Mark)
    租赁车辆(多车)程序
    考试答案对应
  • 原文地址:https://www.cnblogs.com/chong-zuo3322/p/13879960.html
Copyright © 2020-2023  润新知