码迷,mamicode.com
首页 > 其他好文 > 详细

Elasticsearch中的CRUD

时间:2014-06-05 00:22:29      阅读:274      评论:0      收藏:0      [点我收藏+]

标签:elasticsearch   数据   crud   

《玩玩儿Elasticsearch》中简单介绍了一下elasticsearch。这篇文章,我们还是做些基础的学习,在Elasticsearch如何进行CRUD?


假设我们正在创建的一个类似微博的应用,我们就姑且先叫它“kiwi”吧。kiwi这个应用就是一条条消息组成的。

在kiwi中,消息称为ksay。有两个部分组成,一是作者(author),而是消息本身(message)。



Create


curl -X POST http://localhost:9200/kiwi/ksay/ -d ‘{ "author": "rococojie", "message": "I am beautiful"}‘

返回:{"_index":"kiwi","_type":"ksay","_id":"aaX3P2LJSP-dDYVy0USv7Q","_version":1,"created":true}

我们注意到elasticsearch默认不是按照自增的方式帮我们生成id的。而是自动生成22位的URL安全的_id。如刚才的例子中,返回的_id就是aaX3P2LJSP-dDYVy0USv7Q。如果要使用自定义的_id,则操作如下:


curl -X POST http://localhost:9200/kiwi/ksay/1 -d ‘{"author": "jerry", "message": "I hate Tom"}‘

返回:{"_index":"kiwi","_type":"ksay","_id":"1","_version":1,"created":true}



Read

我们这里就只说用id取值


curl -X GET http://localhost:9200/kiwi/ksay/1

返回:{"_index":"kiwi","_type":"ksay","_id":"1","_version":1,"found":true, "_source" : { "author": "jerry", "message": "I hate Tom"}}


如果我们希望返回的知识原来我们存的数据,那么

curl -X GET http://localhost:9200/kiwi/ksay/1/_source

返回:{ "author": "jerry", "message": "I hate Tom"}


curl -X GET http://localhost:9200/kiwi/ksay/10000

返回{"_index":"kiwi","_type":"ksay","_id":"10000","found":false},没有找到我们刚才存的ksay。




Update

curl -X PUT http://localhost:9200/kiwi/ksay/1 -d ‘{"author": "jerry", "message": "I love Tom"}‘

返回:{"_index":"kiwi","_type":"ksay","_id":"1","_version":2,"created":false}

我们注意到这里的_version变为了2,知识因为ksay发生了改变。created返回false,表示没有创建新的文档,只是更新。


虽然Elasticsearch支持进行文档更新,我们需要知道Elasticsearch中存储的文档是不可变的(immutable)。这种所谓的更新实际上是一种假象,在Elasticsearch内部,首先将比较旧的那条数据标明为“已经删除”,然后再把较新的那条数据进行index。(retrieve-change-reindex)


部分更新

curl -X POST http://localhost:9200/kiwi/ksay/1/_update -d ‘{ "doc": {"message": "I hate Tom, again"} }‘

返回:{"_index":"kiwi","_type":"ksay","_id":"1","_version":3}


"doc"中即是我们需要更新的field。Elasticsearch会把最新的field“merge”到原来旧的文档中。这是我们再去查看这条ksay的信息。

curl -X GET http://localhost:9200/kiwi/ksay/1

返回:{"_index":"kiwi","_type":"ksay","_id":"1","_version":3,"found":true, "_source" : {"author":"jerry","message":"I hate Tom, again"}}



Delete

curl -X DELETE http://localhost:9200/kiwi/ksay/1

返回:{"found":true,"_index":"kiwi","_type":"ksay","_id":"1","_version":4}


再尝试去取ksay:

curl -X GET http://localhost:9200/kiwi/ksay/1

返回:{"_index":"kiwi","_type":"ksay","_id":"1","found":false}

就不能在访问到,found的值是false



学会了Elasticsearch最基本的CRUD,我们可以再找些其他好玩儿的来玩儿了

Elasticsearch中的CRUD,布布扣,bubuko.com

Elasticsearch中的CRUD

标签:elasticsearch   数据   crud   

原文地址:http://blog.csdn.net/kiwi_coder/article/details/27109389

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!