Elasticsearch(019):es常见的字段映射类型之数组类型(arrays)

本文深入探讨了Elasticsearch中数组类型的使用方法,包括如何创建数组映射、添加及搜索数组类型的对象,同时强调了数组中所有元素需保持同一数据类型的特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在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哦。数组类型不需要单独设置,建立mapping映射时只需成单个字段一样,在插入的数据时候,插入多个值时,该字段就会自动变成数组类型的。

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

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 的 dynamic templates 功能,通过配置模板来实现字段的映射。 首先,在 Spring Boot 中配置 Elasticsearch 的时候,可以使用 `ElasticsearchRestTemplate` 来操作 Elasticsearch。在创建 `ElasticsearchRestTemplate` 的时候,可以指定一个 `ElasticsearchConverter` 对象,用于将 Java 对象转换成 Elasticsearch 中的文档。在 `ElasticsearchConverter` 中,可以使用 `MappingElasticsearchConverter` 对象来实现字段映射。 具体的操作步骤如下: 1. 配置 `ElasticsearchRestTemplate`,指定 `ElasticsearchConverter` 对象: ```java @Configuration public class ElasticsearchConfig { @Bean public ElasticsearchRestTemplate elasticsearchTemplate(RestHighLevelClient client, ElasticsearchConverter converter) { return new ElasticsearchRestTemplate(client, converter); } @Bean public ElasticsearchConverter elasticsearchConverter() { MappingElasticsearchConverter converter = new MappingElasticsearchConverter(elasticsearchMappingContext()); converter.setTypeMapper(new DefaultElasticsearchTypeMapper(null)); return converter; } @Bean public ElasticsearchMappingContext elasticsearchMappingContext() { return new ElasticsearchMappingContext(); } } ``` 2. 在 `ElasticsearchMappingContext` 中配置 dynamic templates: ```java @Configuration public class ElasticsearchConfig { @Bean public ElasticsearchMappingContext elasticsearchMappingContext() { ElasticsearchMappingContext context = new ElasticsearchMappingContext(); context.setInitialEntitySet(getInitialEntitySet()); context.setSimpleTypeHolder(customSimpleTypeHolder()); context.setApplicationContext(applicationContext); // 配置 dynamic templates context.setDynamicTemplates(Arrays.asList( new DynamicTemplate("camel_case_to_underscore", new MappingBuilder() .match("*") .unmatch("*_text") .mapping(new ObjectMapping() .setType("text") .setNormalizer("lowercase") .addProperty("type", "keyword") .addProperty("fields", new ObjectMapping() .addProperty("raw", new ObjectMapping() .setType("keyword") ) ) ) ) )); return context; } } ``` 上述代码中,我们创建了一个名为 `camel_case_to_underscore` 的 dynamic template,并将其应用到所有字段上(使用 `match("*")`),但排除了以 `_text` 结尾的字段(使用 `unmatch("*_text")`)。对于所有匹配的字段,我们都将其映射为 `text` 类型,使用 `lowercase` 正则表达式将其转换为小写,同时添加了一个 `raw` 子字段,用于排序聚合操作。 这样,我们就完成了将 Java 中的驼峰命名转换为 Elasticsearch 中的下划线命名的操作。在使用 `ElasticsearchRestTemplate` 进行 CRUD 操作时,会自动将 Java 对象转换为 Elasticsearch 中的文档,并将字段映射为下划线命名。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值