ElasticSearch-document文档数据-增删改
文档就是相当于每条记录。
每个文档(数据记录行)都有几个元数据,分别是:
- _index,表示该文档是那个索引中的。
- _type,表示文档的类型
- _id,文档的唯一ID编号
- _score,相关性分数。
添加文档(添加数据)
POST /库名/类型名[/id]
注意:不给ID的化,则系统默认自己生成ID
例子:
POST http://127.0.0.1:9200/news/news/
{
"article_id": 456,
"user_id": 10,
"title": "python如何获取时间戳!"
}


获取文档数据等信息
GET /库名/类型名/id
例子:
GET http://127.0.0.1:9200/news/news/111
**查询结果:**
{
"_index": "news",
"_type": "news",
"_id": "111",
"_version": 1,
"_seq_no": 1,
"_primary_term": 1,
"found": true,
"_source": {
"article_id": 12,
"user_id": 1,
"title": "scrapy爬虫框架入门"
}
}
判断文档是否存在
1、除了直接使用查询外(GET请求),还是可以发送HEAD请求也可以判断文档是否存在。
HEAD 索引库名/类型名/文档ID
查询时只显示某个字段的数据
https://www.elastic.co/guide/en/elasticsearch/reference/6.8/docs-get.html#get-source-filtering
一般过滤
GET /库名/类型名/id?_source=字段名,字段名,....
例:只获取user_id和title字段的数据
GET http://127.0.0.1:9200/news/news/111?_source=user_id,title
查询结果:
{
"_index": "news",
"_type": "news",
"_id": "111",
"_version": 1,
"_seq_no": 1,
"_primary_term": 1,
"found": true,
"_source": {
"user_id": 1,
"title": "scrapy爬虫框架入门"
}
}
更详细的过滤
GET /库名/类型名/id?_source_includes=字段名&_source_excludes=字段名
_source_includes
_source_excludes
**这两个参数都采用逗号分隔的字段列表或通配符表达式。**
例如:
GET twitter/_doc/0?_source_includes=*.id&_source_excludes=entities
获取文档中的数据,其他信息不要
https://www.elastic.co/guide/en/elasticsearch/reference/6.8/docs-get.html#_source
按照之前的查询URL,我们一般会返回信息如下:
{
"_index": "news",
"_type": "news",
"_id": "111",
"_version": 1,
"_seq_no": 1,
"_primary_term": 1,
"found": true,
"_source": {
"user_id": 1,
"title": "scrapy爬虫框架入门"
}
}
我们可以看到除了文档数据,还有很多其他的字段信息,如果你向要只拿文档信息可以用这个查询URL
GET /库名/类型名/id/_source
并且,同样支持过滤查询:
如:
GET /库名/类型名/id/_source?_source_include=xxx&_source_exclude=xxxx
修改文档的某个值
POST <索引名>/<类型名>/<文档ID>/_update
{
"doc" : {
"字段名" : "新的值"
}
}
例子:
POST http://127.0.0.1:9200/news/news/111/_update
{
"doc": { //doc表示以文档形式进行部分更新。es还支持用script脚本形式更新值,具体可以参考官方文档。一般不怎么用...
"title": "开玩笑呀....."
}
}
修改结果返回:
{
"_index": "news",
"_type": "news",
"_id": "111",
"_version": 2, // version每修改一次就会累加1
**"result": "updated",**
"_shards": {
"total": 2, //表示应该在多少个分片副本(主分片和副本分片)上执行了索引操作
**"successful": 1,**
"failed": 0
},
"_seq_no": 2, // 每修改一次就会累加1
"_primary_term": 1
}
还有一种方式,但是这种方式等同于重定义整个文档:
用下面这种方式修改文档数据,如果文档中其他字段不需要修改,你也要传递值,否则都会被清空!
PUT /库名/类型名/id
{
"字段名": "值"
}
删除文档数据
DELETE /<索引库名>/<类型名>/<文档ID>
如:
DELETE http://127.0.0.1:9200/news/news/111
返回结果:
{
"_index": "news",
"_type": "news",
"_id": "111",
"_version": 4,
**"result": "deleted",**
"_shards": {
"total": 2,
"successful": 1,
"failed": 0
},
"_seq_no": 4,
"_primary_term": 1
}
根据查询语句来删除数据
参考:
他用的就是查询的语法
https://www.elastic.co/guide/en/elasticsearch/reference/6.8/docs-delete-by-query.html
ElasticSearch-document文档数据-增删改的更多相关文章
- Elasticsearch之文档的增删改查以及ik分词器
文档的增删改查 增加文档 使用elasticsearch-head查看 修改文档 使用elasticsearch-head查看 删除文档 使用elasticsearch-head查看 查看文档的三种方 ...
- 分布式搜索elasticsearch 索引文档的增删改查 入门
1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口. RESTful接口URL的格式: http://localhost:9200/ ...
- head插件对elasticsearch 索引文档的增删改查
1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口. RESTful接口URL的格式: http://localhost:9200 ...
- Elasticsearch 索引文档的增删改查
利用Elasticsearch-head可以在界面上(http://127.0.0.1:9100/)对索引进行增删改查 1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演 ...
- MongoDB文档的增删改操作
上一篇文章中介绍了MongoDB的一些基本知识,同时看到了怎么启动一个MongoDB服务,并且通过MongoDB自带的shell工具连接到了服务器. 这一次,就通过MongoDB shell介绍一下对 ...
- Java对XML文档的增删改查
JAVA增删改查XML文件 最近总是需要进行xml的相关操作. 不免的要进行xml的读取修改等,于是上网搜索,加上自己的小改动,整合了下xml的常用操作. 读取XML配置文件 首先我们需要通过Do ...
- Mongodb的基本操作-数据库 集合 文档的增删改查
数据库操作: //查看有哪些数据库 > show dbs local 0.078GB mydb 0.078GB //use操作将切换到一个数据库 如果数据库存在将直接切换 如果不存在 那么 ...
- 对mongo文档的增删改操作
在mongo db 中增加.删除.修改文档有好多方法,这里简单记录一下我所知道的一些方法. 前置条件: 1.创建study数据库 use study; 2.创建persons集合,当第一次向pers ...
- 使用dom4j技术对xml文档进行增删改练习(一)
整个流程如下面代码所以,并对一些重要代码意义做出详细解释: import java.io.File; import java.io.FileOutputStream; import org.dom4j ...
- mongodb对数组元素及内嵌文档进行增删改查操作(转)
from:https://my.oschina.net/132722/blog/168274 比如我有一个user类,他包含一个标签属性,这个标签是一个数组,数组里面的元素是内嵌文档,格式如下: &l ...
随机推荐
- Unity UGUI的Scrollbar(滚动条)组件的介绍及使用
Unity UGUI的Scrollbar(滚动条)组件的介绍及使用 一.什么是Scrollbar组件? Scrollbar组件是Unity中UGUI系统提供的一种UI组件,主要用于在UI界面中提供滚动 ...
- LeetCode 周赛上分之旅 #45 精妙的 O(lgn) 扫描算法与树上 DP 问题
️ 本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 和 BaguTree Pro 知识星球提问. 学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越 ...
- MySQL高级13-MySQL管理工具
一.系统数据库 MySQL数据库安装完成后,自带了四个数据库: mysql数据库:存储MySQL服务器正常运行所需要的各种信息如时区.主从.用户.权限等 infomation_schema:提供了访问 ...
- Abp vNext 依赖注入
文章目录 介绍 ABP的依赖注入系统是基于Microsoft的依赖注入扩展库(Microsoft.Extensions.DependencyInjection nuget包)开发的.所以我们采用dot ...
- SQL运用full join连接,decode函数,nvl函数进行列转行
背景说明:full join连接,decode函数,nvl函数,结合生产背景理解更深刻: test_A表是现金业主某时间段的收益:test_B表是非现金业主某时间段的收益:对于业主,test_A表与t ...
- 下载、安装CAN-EYE植被参数工具
本文介绍植被指数计算软件CAN-EYE的下载.安装方法. CAN-EYE软件是由法国国家农业研究院(French National Institute of Agricultural Rese ...
- 什么是DCloud
什么是DCloud1.什么是Dcloud2.主要包括 1. 开发工具 2. 前端框架 3. uniCloud 4. 5+app 5. MUI 6. wap2app1.什么是Dcloud 1. Dclo ...
- HDU1702 ACboy needs your help again! 题解
#include <iostream> #include <string> #include <queue> #include <stack> usin ...
- 多维评测指标解读第17届MSU世界编码器大赛全高清10bit赛道结果
超高清视频纤毫毕现的关键一环. 01 主要指标多项第一,带宽节省48% 近日,第17届MSU世界编码器大赛全高清10bit赛道成绩揭晓,阿里自研的H.266/VVC编码器Ali266在该赛道最高效的1 ...
- zabbix 监控 IPMI
1.IPMI的相关介绍: 智能平台管理接口(Intelligent Platform Management Interface)原本是一种Intel架构的企业系统的周边设备所采用的一种工业标准.IPM ...