Elasticsearch(019):es常见的字段映射类型之数组类型(arrays)
程序员文章站
2022-04-23 15:46:02
...
在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个结果
推荐阅读
-
Elasticsearch(017):es常见的字段映射类型之嵌套类型(nested)
-
Elasticsearch(023):es常见的字段映射类型之IP类型
-
Elasticsearch(021):es常见的字段映射类型之地理点类型(geo-point)
-
Elasticsearch(025):es常见的字段映射类型之单词计数类型(token count)
-
Elasticsearch(019):es常见的字段映射类型之数组类型(arrays)
-
Elasticsearch(020):es常见的字段映射类型之二进制类型(binary)
-
Elasticsearch(016):es常见的字段映射类型之对象类型(object)
-
Elasticsearch(024):es常见的字段映射类型之 连接类型(join type)
-
Elasticsearch(022):es常见的字段映射类型之地理形状类型(geo_shape、多边的复杂的地址形状)
-
Elasticsearch(014):es常见的字段映射类型之date(日期类型)