在使用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”兩個欄位。
原創文章,作者:KDIWT,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/368410.html
微信掃一掃
支付寶掃一掃