[翻译]ElasticSearch官方文档-数据的修改

本文翻译自:https://www.elastic.co/guide/en/elasticsearch/reference/current/_modifying_your_data.html

本文是Elasticsearch的入门文档,将会介绍ElasticSearch中关于修改,更新和删除数据的相关操作。

修改数据

Elasticsearch近乎实时提供数据操作和搜索功能。默认情况下,你可以在你索引/更新/删除操作数据的一秒钟延迟(刷新间隔)后,看到其出现在搜索结果中。这是与其他平台(如SQL)的重要区别,这类型的平台数据在事务完成后可以立即使用。

索引和替换文档

我们以前看过我们如何索引一个文档。如下:

PUT /customer/external/1?pretty
{
  "name": "John Doe"
}

接下来,将上述将指定的文档索引到外部类型,ID为1的自定义索引。如果我们再次使用不同的(或相同)文档执行上述命令,Elasticsearch将替换(即重新索引),新的文档现有的ID为1,且出现在顶部:

PUT /customer/external/1?pretty
{
  "name": "Jane Doe"
}

以上将ID为1的文档的名称从“John Doe”更改为“Jane Doe”。另一方面,如果我们使用不同的ID,则新的文档将被编入索引,并且已经在索引中的现有文档保持不变(相当于复制),如下:

PUT /customer/external/2?pretty
{
  "name": "Jane Doe"
}

以上索引为一个ID为2的新文档。索引时,ID部分是可选的。如果没有指定,Elasticsearch将生成一个随机ID,然后使用它来对文档进行索引。索引API调用的返回值中包含Elasticsearch生成的实际ID(或者我们在前面的例子中明确指定的任何内容)。

此示例显示如何索引没有显式ID的文档:

POST /customer/external?pretty
{
  "name": "Jane Doe"
}

请注意,在上述情况下,我们使用POST动词而不是PUT,因为我们没有指定ID。

更新文档

除了能够索引和替换文档外,我们还可以更新文档。注意,虽然Elasticsearch实际上并没有在底层进行及时更新。每当我们进行更新时,Elasticsearch都会删除旧的文档,然后对一个新文档进行索引(相当于复制),同时更新一次应用更新。

此示例显示如何通过将名称字段更改为“Jane Doe”,以此来更新我们以前的文档(ID为1):

POST /customer/external/1/_update?pretty
{
  "doc": { "name": "Jane Doe" }
}

此示例显示如何通过将名称字段更改为“Jane Doe”来更新我们以前的文档(ID为1),同时在其中添加一个年龄字段:

POST /customer/external/1/_update?pretty
{
  "doc": { "name": "Jane Doe", "age": 20 }
}

也可以使用简单的脚本来执行更新。此示例使用脚本将年龄增加5:

POST /customer/external/1/_update?pretty
{
  "script" : "ctx._source.age += 5"
}

在上面的例子中,ctx._source是指当前的源文档即将被更新。

请注意,在撰写本文时,一次只能对单个文档执行更新。在将来,Elasticsearch可能会提供给予查询条件的多个文档的更新功能(如SQL UPDATE-WHERE语句)。

删除文档

删除文档是相当简单的。此示例显示如何删除我们之前的ID为2的客户:

DELETE /customer/external/2?pretty

请参阅_delete_by_query API以删除与特定查询相匹配的所有文档。值得注意的是,删除整个索引效率更高,而不是使用“按查询删除”API删除符合的文档。

批量处理

除了能够索引,更新和删除单个文档之外,Elasticsearch还提供了使用_bulk API批量执行上述任何操作的功能。这个功能很重要,因为它提供了一个非常有效的机制来尽可能快地进行多个操作,尽可能少的网络往返行程。

作为一个快速示例,以下调用在一个批量操作中指定两个文档(ID 1 - John Doe和ID 2 - Jane Doe):

POST /customer/external/_bulk?pretty
{"index":{"_id":"1"}}
{"name": "John Doe" }
{"index":{"_id":"2"}}
{"name": "Jane Doe" }

此示例更新第一个文档(ID为1),然后在一个批量操作中删除第二个文档(ID为2):

POST /customer/external/_bulk?pretty
{"update":{"_id":"1"}}
{"doc": { "name": "John Doe becomes Jane Doe" } }
{"delete":{"_id":"2"}}

请注意,对于删除操作,在它之后没有相应的源文档,因为删除只需要待删除的文档的ID。

由于其中一个操作失败,Bulk API不会失败。如果一个单一的动作由于任何原因而失败,它将继续处理其后的其余动作。当批量API返回时,它将为每个操作提供一个状态(按照发送的相同顺序),以便·可以检查特定操作是否失败。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容