elasticsearch(4)mapping 相关

本文探讨了ES中analyzed、not_analyzed及no三种分词方式的区别,通过实例展示了如何存储复杂结构数据,并深入解释了为何需要手动创建mapping以满足定制化需求。

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

1.analyzed 分词

not_analyzed 不分词

no 不能搜索

2.put /company/emp/2
{
  "address":{
    "country":"china",
    "province":"guangdongsheng",
    "city":"guangzhoushi"
  },
  "name":"jack",
  "age":26,
  "sex":"male",
  "authors":[
    {"age":26,"name":"Jack White"},
    {"age":23,"name":"Tom John"}
    ]
}

address这个字段是object类型,对应的底层数据结构

addres.country: china

authors也是一个复杂结构

authors.age :[26,23]

authors.name:[Jack White,Tom John]

3.为什么会有mapping

因为dynamic mapping建立的时候字段类型是自动生成的,不同类型的字段类型对应的分词器也不一样,不能满足定制化的需求,所以可以通过人工建立mapping,注意mapping不允许删除和修改,只允许添加

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值