zoukankan      html  css  js  c++  java
  • 向elasticsearch中动态添加字段报错问题和向elasticsearch中添加嵌套数据类型数据--工作学习记录

    今天在对已有的es库中进行update操作时发现update操作失败(提示说是操作不允许)。然后发现原因是:es中type的“dynamic”属性为“strict”

    然后感觉有两种方法解决:

    1.向type中新增字段,再动态添加

    2.修改es中dynamic属性为true(这种的话改动太大就算了)

    之后我就通过第一种方法进行解决。但是,要添加的数据类型是嵌套数据类型。

    如果就像普通的数据那样进行添加的话,es引擎内部会把对象数组展开成扁平的数据结构,数据之间的依赖关系会丢失。

    例如:"tag":[

                 {

                   "tagname":"测试标签1",

                   "userid":"admin1"

                 }

                {

                  "tagname":"测试标签2",

                  "userid":"admin2"

                 }

           ]

    像这样添加数据后es会解析成  {

                                                       "tag.tagname":["测试标签1","测试标签2"],

                                                       "tag.userid":["admin1","admin2"]

                                                     }

    这样的话admin1添加的标签虽然是"测试标签1",但是经过es这么一解析,我们就不能通过admin1来查出他所添加的标签了。

    为了解决这个问题,在添加该对象数组的时候就把它设置成嵌套类型。具体操作如下:

    PUT /indextest/_mapping/typetest

    {

      "typetest":{

           "properties":{

                 "tag":{

                    "type":"nested",

                     "properties":{

          "userid":{"type": "text"},

          "tagname":{"type": "text"}

                      }

                 }

             }

       }

    }

  • 相关阅读:
    如何编写一个shellcode
    SQL_MODE设置讲解
    centOS7 安装man中文手册
    CentOS Docker 安装
    windows下php的各个版本下载地址
    cnetos7最小化安装ifconfig命令找不到怎么办
    Linux netstat命令详解
    Linux查看磁盘占用率及文件大小
    Linux下ps命令详解 Linux下ps命令的详细使用方法
    支付接口中常用的加密解密以及验签rsa,md5,sha
  • 原文地址:https://www.cnblogs.com/olzoooo/p/11425578.html
Copyright © 2011-2022 走看看