【ES】--Elasticsearch的Nested类型介绍

一、问题现象

问题现象:在实际项目中,一些数组存储的字段,根据匹配条件去查询经常会查询到一些“其他不需要”的数据,为什么会出现这种情况?
----这种问题现象,就是ES的Object类型的数据扁平化存储问题

nested类型是object一种数据类型,对象数组的优先选择类型。Nested将数组中的每个对象作为单独的隐藏文档(hidden separate document)进行索引。nested属于object类型的一种,是Elasticsearch中用于复杂类型对象数组的索引操作。
nested类型数据是单独存储很耗资源,因此默认一个index最多只有50个nested字段。此外,虽然nested是单独存储的,但是其字段数也算入index总字段数,默认最多1000个。

二、普通数组类型

普通数组的mapping参数设置

 "word_one": {
   
          "properties": {
   
            "desc": {
   
              "type": "text",
              "fields": {
   
                "keyword": {
   
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "no": {
   
              "type": "text",
              "fields": {
   
                "keyword": {
   
                  "type": "keyword",
                  "ignore_above": 256
                }
              }
            },
            "sid": {
   
              "type": "long"
            },
            "sign": {
   
              "type": "boolean"
            }
          }
        }

现在进行搜索sid、desc字段数据。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
现象结论:word_one是普通数组List,多个must匹配条件会匹配整个List数组数据,而不是每个Bean去匹配。

1、为什么普通数组类型匹配不准?

原因分析:当字段是普通数组类型,其实在ES中,每个对象元素的属性值被扁平化存储在了数组中,已丢失了对应关系,因此无法保证搜索的准确。

{
   
          "app_id": "42533",
          "word_one": [
            {
   
              "desc": "南京有好高中么",
              "no": "0963",
              "sid": 2002,
              "sign": false
            },
            {
   
              "desc": "雨花区面积多大",
              "no": "05380",
              "sid": 2003,
              "sign": false
            }
          ]
        }

被扁平化存储到ES中,如下所示

 {
   
        "app_id"
  • 16
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DreamBoy_W.W.Y

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值