文档就是相当于每条记录。

每个文档(数据记录行)都有几个元数据,分别是

  • _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

修改文档的某个值

https://www.elastic.co/guide/en/elasticsearch/reference/6.8/docs-update.html#_updates_with_a_partial_document

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文档数据-增删改的更多相关文章

  1. Elasticsearch之文档的增删改查以及ik分词器

    文档的增删改查 增加文档 使用elasticsearch-head查看 修改文档 使用elasticsearch-head查看 删除文档 使用elasticsearch-head查看 查看文档的三种方 ...

  2. 分布式搜索elasticsearch 索引文档的增删改查 入门

    1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口. RESTful接口URL的格式: http://localhost:9200/ ...

  3. head插件对elasticsearch 索引文档的增删改查

    1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口.  RESTful接口URL的格式: http://localhost:9200 ...

  4. Elasticsearch 索引文档的增删改查

    利用Elasticsearch-head可以在界面上(http://127.0.0.1:9100/)对索引进行增删改查 1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演 ...

  5. MongoDB文档的增删改操作

    上一篇文章中介绍了MongoDB的一些基本知识,同时看到了怎么启动一个MongoDB服务,并且通过MongoDB自带的shell工具连接到了服务器. 这一次,就通过MongoDB shell介绍一下对 ...

  6. Java对XML文档的增删改查

    JAVA增删改查XML文件   最近总是需要进行xml的相关操作. 不免的要进行xml的读取修改等,于是上网搜索,加上自己的小改动,整合了下xml的常用操作. 读取XML配置文件 首先我们需要通过Do ...

  7. Mongodb的基本操作-数据库 集合 文档的增删改查

    数据库操作: //查看有哪些数据库 > show dbs local  0.078GB mydb   0.078GB //use操作将切换到一个数据库 如果数据库存在将直接切换 如果不存在 那么 ...

  8. 对mongo文档的增删改操作

    在mongo db 中增加.删除.修改文档有好多方法,这里简单记录一下我所知道的一些方法. 前置条件: 1.创建study数据库  use study; 2.创建persons集合,当第一次向pers ...

  9. 使用dom4j技术对xml文档进行增删改练习(一)

    整个流程如下面代码所以,并对一些重要代码意义做出详细解释: import java.io.File; import java.io.FileOutputStream; import org.dom4j ...

  10. mongodb对数组元素及内嵌文档进行增删改查操作(转)

    from:https://my.oschina.net/132722/blog/168274 比如我有一个user类,他包含一个标签属性,这个标签是一个数组,数组里面的元素是内嵌文档,格式如下: &l ...

随机推荐

  1. CodeForces 1388C Uncle Bogdan and Country Happiness

    题意 给一棵\(n\)节点的树,每个节点有\(a[i]\)个人住,他们从\(1\)号节点回家,回家路上可能从开心的状态变成不开心的状态(但不可以由不开心变为开心),每个节点有个探测器,会探测经过该节点 ...

  2. textarea自动适应高度

    textarea自动适应高度,兼容IE/Firefox.chrome 代码:<textarea name="textarea" id="textarea" ...

  3. Nomad 系列-Nomad+Traefik+Tailscale 集成实现零信任安全

    系列文章 Nomad 系列文章 Traefik 系列文章 Tailscale 系列文章 概述 终于到了令人启动的环节了:Nomad+Traefik+Tailscale 集成实现零信任安全. 在这里: ...

  4. EXE一机一码加密大师1.3.0更新

    EXE一机一码打包加密大师可以打包加密保护EXE文件,同时给EXE文件添加上一机一码认证,或者静态密码,不同的电脑打开加密后的文件需要输入不同的激活码才能正常使用,保护文件安全,方便向用户收费. 1. ...

  5. 在Vue2和Vue3中JSX的使用集锦

    Vue2安装JSX支持 有时候,我们使用渲染函数(render function)来抽象组件,而渲染函数使用Vue的h函数来编写Dom元素相对template语法差别较大,体验不佳,这个时候就派 JS ...

  6. 7-MySQL函数

    1.分组group by 在MySQL中,GROUP BY的意思是"分组查询",它可以根据一个或多个字段对查询结果进行分组. GROUP BY的作用是通过一定的规则将一个数据集划分 ...

  7. Springboot中使用线程池的三种方式

    前言 多线程是每个程序员的噩梦,用得好可以提升效率很爽,用得不好就是埋汰的火葬场. 这里不深入介绍,主要是讲解一些标准用法,熟读唐诗三百首,不会作诗也会吟. 这里就介绍一下springboot中的多线 ...

  8. MySQL的驱动表与被驱动表

    驱动表与被驱动表的含义 在MySQL中进行多表联合查询时,MySQL会通过驱动表的结果集作为基础数据,在被驱动表中匹配对应的数据,匹配成功合并后的临时表再作为驱动表或被驱动表继续与第三张表进行匹配合并 ...

  9. CC BY-SA 4.0原文及翻译

    CC BY-SA 4.0原文及翻译 英文参考链接 中文参考链接 原文: Attribution 4.0 International (CC BY 4.0) This is a human-readab ...

  10. 16. 从零开始编写一个类nginx工具, 反向代理upstream源码实现

    wmproxy wmproxy将用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器,后续将实现websocket代理, 内外网穿透等, 会将实现过程分享出来, 感 ...