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/ -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的更多相关文章
- Elasticsearch中最重要的文档CRUD要牢记
Elasticsearch文档CRUD要牢记 转载参考:https://juejin.im/post/5ddbf298e51d4523053c42e7 在Elasticsearch中,文档(docum ...
- 如何在Elasticsearch中安装中文分词器(IK+pinyin)
如果直接使用Elasticsearch的朋友在处理中文内容的搜索时,肯定会遇到很尴尬的问题--中文词语被分成了一个一个的汉字,当用Kibana作图的时候,按照term来分组,结果一个汉字被分成了一组. ...
- elasticsearch中常用的API
elasticsearch中常用的API分类如下: 文档API: 提供对文档的增删改查操作 搜索API: 提供对文档进行某个字段的查询 索引API: 提供对索引进行操作,查看索引信息等 查看API: ...
- 在Elasticsearch中查询Term Vectors词条向量信息
这篇文章有点深度,可能需要一些Lucene或者全文检索的背景.由于我也很久没有看过Lucene了,有些地方理解的不对还请多多指正. 更多内容还请参考整理的ELK教程 关于Term Vectors 额, ...
- elasticsearch中的API
elasticsearch中的API es中的API按照大类分为下面几种: 文档API: 提供对文档的增删改查操作 搜索API: 提供对文档进行某个字段的查询 索引API: 提供对索引进行操作 查看A ...
- 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作(二)
CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...
- 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作
http://www.cnblogs.com/wgp13x/p/4934521.html 内容一样,样式好的版本. 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据 ...
- ElasticSearch中的简单查询
前言 最近修改项目,又看了下ElasticSearch中的搜索,所以简单整理一下其中的查询语句等.都是比较基础的.PS,好久没写博客了..大概就是因为懒吧.闲言少叙书归正传. 查询示例 http:// ...
- elasticsearch中的mapping映射配置与查询典型案例
elasticsearch中的mapping映射配置与查询典型案例 elasticsearch中的mapping映射配置示例比如要搭建个中文新闻信息的搜索引擎,新闻有"标题".&q ...
随机推荐
- 高级函数-decode
decode(字段或计算表达式, 条件值1,结果值1, 条件值2,结果值2[,默认值] ) if(字段或计算表达式 == 条件值1 ...
- 【转】 C#获取当前程序运行路径的方法集合
[转] C#获取当前程序运行路径的方法集合 //获取当前进程的完整路径,包含文件名(进程名). string str = this.GetType().Assembly.Location; resul ...
- 极路由4pro(HC5962)安装python
基本配置 其实极路由4.极路由4 pro.极路由B70都是一个型号的(HC5962) CPU:MT7621AT + MT7612EN + 7603EN 内存:256MB DDR3 RAM 闪存:128 ...
- 8个超实用的Java测试工具和框架
Java入门 如果你才刚开始接触Java世界,那么要做的第一件事情是,安装JDK——Java Development Kit(Java开发工具包),它自带有Java Runtime Environme ...
- Hive分区表与分桶
分区表 在Hive Select查询中.通常会扫描整个表内容,会消耗非常多时间做不是必需的工作. 分区表指的是在创建表时,指定partition的分区空间. 分区语法 create table tab ...
- SSH公钥认证
一.实验的目的 了解密钥对的创建和使用,掌握免password远程登录和远程操作 二.实验环境 本地主机 rh1: 192.168.233.3/24 远程主机 rh2: 192.168.233.4/2 ...
- IE input X 去掉文本框的叉叉和password输入框的眼睛图标
IE input X 去掉文本框的叉叉和password输入框的眼睛图标 从IE 10開始,type="text" 的 input 在用户输入内容后.会自己主动产生一个小叉叉(X) ...
- App 签名过期或泄露怎么办?别担心,Google 已经给出解决方案!
一.序 在将 App 发布到市场之前,很重要的一个步骤就是为 APK 进行签名,大部分时候,这个操作隐藏在了打包的流程中,而不被我们注意到. 签名的作用,除了证明 App 的所有权之外,还可以帮助 A ...
- UVALive 4222 /HDU 2961 Dance 大模拟
Dance Problem Description For a dance to be proper in the Altered Culture of Machinema, it must abid ...
- bzoj2150: 部落战争(匈牙利)
2150: 部落战争 题目:传送门 题解: 辣鸡数据..毁我AC率 先说做法,很容易就可以看出是二分图匹配的最小路径覆盖(可能是之前不久刚做过类似的题) 一开始还傻逼逼的去直接连边然后准备跑floyd ...