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个结果