您的位置:

ES中添加字段的方法

在使用ES过程中,添加字段是一项常见的操作。本文将就ES添加字段,从以下几个方面详细阐述:

一、通过PUT命令添加字段

PUT命令是ES中的索引API,可以用来创建、修改索引,也可以直接用来添加字段。它的基本语法如下:

PUT /index/type/id
{
  "field_name": "field_value"
}

其中,index表示索引名,type表示类型名(可以省略),id表示文档id(可以省略)。具体来说,如果要在index名为myindex的索引上添加一个包含"name"和"age"两个字段的文档,可以使用如下命令:

PUT /myindex/_doc/1
{
    "name": " John",
    "age": "30"
}

上述命令中,"_doc"表示索引的默认类型名。如果未指定类型,则默认使用该类型。

二、通过mapping添加新字段

ES支持在索引创建时指定mapping,这可以使我们在添加文档时自动添加新字段。mapping是我们在创建索引时指定的用于定义字段数据类型和属性的元数据。下面是一个例子:

PUT myindex
{
   "mappings":{
      "properties":{
         "name":{
            "type":"text"
         },
         "age":{
            "type":"integer"
         }
      }
   }
}

上面代码中,我们指定了myindex索引包含"name"和"age"两个字段,"text"指定"name"字段的数据类型,"integer"指定"age"字段的数据类型。

如果想为现有索引添加新字段,在修改对应mapping,增加对应字段的属性即可实现。例如,如下代码就增加了myindex索引中的"email"字段:

PUT myindex/_mapping
{
   "properties":{
      "email":{
         "type":"keyword"
      }
   }
} 

三、通过reindex添加新字段

如果想要为现有索引添加新字段,还可以通过reindex的方式。具体的流程是先创建一个新的索引并指定新旧mapping,再通过reindex将旧索引中的文档移动到新索引。下面是一个例子:

PUT mynewindex
{
   "mappings":{
      "properties":{
         "name":{
            "type":"text"
         },
         "age":{
            "type":"integer"
         },
         "email":{
            "type":"keyword"
         }
      }
   }
}

POST _reindex
{
  "source": {
    "index": "myoldindex"
  },
  "dest": {
    "index": "mynewindex"
  }
} 

上面的代码中,我们先创建了一个新的索引mynewindex,并通过mapping指定了新的字段。再通过reindex命令将旧索引myoldindex中的文档重新索引到新索引mynewindex中。

四、通过script添加字段

如果要向现有索引中的文档添加字段,可以使用script来更新该文档。ES的script是使用Lucene的Expression语言编写的,它支持用于更新字段值的变量、运算符和函数。下面是一个例子,向索引名称为myindex,id为1的文档中添加一个名为"city"的新字段:

POST myindex/_update/1
{
  "script": {
    "source": "ctx._source.city = 'Beijing'",
    "lang": "painless"
  }
}

上面的代码中,script的source中的语句作用是为文档中的"_source"对象添加一个"city"字段,其值为"Beijing"。

五、通过Bulk API添加字段

Bulk API是ES中用于批处理的API,它可以一次性提交多个文档操作。如果想要为多篇文档添加同一个新字段,可以使用Bulk API批量提交。具体的命令如下:

POST myindex/_bulk
{"index":{"_id": "1"}}
{"name":"Mike","age":20}
{"index":{"_id": "2"}}
{"name":"Lucy","age":22}
{"index":{"_id": "3"}}
{"name":"Tom","age":21}

上述命令将向myindex索引添加3条记录,每条数据都包含了"name"和"age"两个字段。