原文:Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD

版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。

下面的操作 都是是kibana 中的 dev Tools工具操作的

一、索引

一个索引就是一个拥有几分相似特征的文档的集合。比如说,你可以有一个客户数据的索引,另一个产品目录的索引,还有一个订单数据的索引。一个索引由一个名字来标识(必须全部是小写字母的),并且当我们要对对应于这个索引中的文档进行索引、搜索、更新和删除的时候,都要使用到这个名字。


  1. #查看所有索引相关信息
  2. GET /_cat/indices?v
  3. #创建索引
  4. PUT customer
  5. #查看所有索引相关信息
  6. GET customer
  7. #删除索引
  8. DELETE customer
  9. #查看索引的文档总数
  10. GET kibana_sample_data_ecommerce/_count
  11. #查看前10条文档,了解文档格式
  12. POST kibana_sample_data_ecommerce/_search
  13. {
  14. }

二、文档CRUD

一个文档是一个可被索引的基础信息单元。比如,你可以拥有某一个客户的文档,某一个产品的一个文档,当然,也可以拥有某个订单的一个文档。文档以 JSON(Javascript Object Notation)格式来表示。

1 create 创建文档

_create 指定类型为create并不是type名称 默认是_doc 指定 ID 如果已经存在,就报错


  1. #create document. _create 指定类型为create并不是type名称 默认是_doc 指定 ID 如果已经存在,就报错
  2. PUT users/_create/1
  3. {
  4.      "user" : "Jack2",
  5.     "post_date" : "2019-05-15T14:12:12",
  6.     "message" : "trying out Elasticsearch"
  7. }

如果是id是1文档存在 在创建就会报错

2 index  创建文档

index和 create不一样地方:index 如果文档不错,就索引新的文档。如果文档存在就覆盖原有的文档内容。版本信息+1

3 GET查询索引

get 根据文档id查询 文档内容

4 Update 修改文档

update 修改文档 不会删除原文档 而是在 文档的基础上更新文档中的字段内容

#  _update 才会根据文档中字段信息 在原文档上增加字段 必须带有doc

  POST users/_update/1/

   {

    "doc":{

        "post_date" : "2019-05-18T14:12:12",

        "message" : "trying out ElasticsearchOut",

        "phone" : "1806185",

        "pubtest":[1,2,3],

        "pubtest2":"[1,2,3]"

     }

 }

5 DELETE 删除文档

### Delete by Id

     # 删除文档

    DELETE users/_doc/1

6 查看索引的 maping 信息

maping 相当于表的 schema

GET users/_mapping

三 文档批量操作

bulk api 批量操作

1、bulk相当于数据库里的bash操作。

2、引入批量操作bulk,提高工作效率,你想啊,一批一批添加与一条一条添加,谁快?

3、bulk API可以帮助我们同时执行多个请求

4、bulk的格式:

action:index/create/update/delete

metadata:_index,_type,_id

request body:_source (删除操作不需要加request body)

{ action: { metadata }}

{ request body        }

单条操作失败不会影响其他操作

5、bulk里为什么不支持get呢?

  答:批量操作,里面放get操作,没啥用!所以,官方也不支持。

6、create 和index的区别

  如果数据存在,使用create操作失败,会提示文档已经存在,使用index则可以成功执行。

7、bulk一次最大处理多少数据量?

  bulk会把将要处理的数据载入内存中,所以数据量是有限制的,最佳的数据量不是一个确定的数值,它取决于你的硬件,你的文档大小以及复杂性,你的索引以及搜索的负载。

  一般建议是1000-5000个文档,如果你的文档很大,可以适当减少队列,大小建议是5-15MB,默认不能超过100M,可以在es的配置文件(即$ES_HOME下的config下的elasticsearch.yml)中。


  1. ### Bulk 操作 批量操作,其中一步错误,不影响其他操作
  2. PUT _bulk
  3. {"index":{"_index":"test","_id":"1"}}
  4. {"name":"dukun","post_date" : "2019-05-18T14:12:12","age":18,"phone" : "1806185","sex":"男"}
  5. {"index":{"_index":"test","_id":"2"}}
  6. {"name":"dukun02","post_date" : "2019-05-18T14:12:12","age":25,"phone" : "19888","sex":"男"}
  7. {"create":{"_index":"test","_id":"3"}}
  8. {"name":"dukun03","post_date" : "2019-05-19T14:12:12"}
  9. {"update":{"_index":"test","_id":"3"}}
  10. {"doc" :{"name":"dukun04","phone" : "1806185","age":28,"sex":"男"}}
  11. {"delete":{"_index":"test","_id":"4"}}

mget 批量读取

批量操作可以减少网络连接所带来的开销,提供性能。


  1. ##批量查询mget
  2. GET /_mget
  3. {
  4. "docs":[
  5. {
  6. "_index" : "test",
  7. "_id" : "1"
  8. },
  9. {
  10. "_index" : "test",
  11. "_id" : "3"
  12. }
  13. ]
  14. }
  15. ##批量查询mget url中指定索引 可以简化如下
  16. GET test/_mget
  17. {
  18. "ids":[1,2,3]
  19. }
  20. #批量查询mget 中_source过滤默认_source字段会返回所有的内容,
  21. 你也可以通过_source进行过滤。
  22. 比如使用_source,_source_include 包含字段,_source_exclude 查询排除字段. "_source" : false 不显示字段
  23. GET test/_mget
  24. {
  25. "docs":[
  26. { "_id":"1",
  27. "_source" : false
  28. },
  29. { "_id":"1",
  30. "_source" : true
  31. },
  32. { "_id":"2",
  33. "_source" : ["name","age"]
  34. },
  35. {
  36. "_id":"3",
  37. "_source":{
  38. "include":["name","age","sex"]
  39. }
  40. },
  41. {
  42. "_id":"3",
  43. "_source":{
  44. "exclude":["name","age","sex"]
  45. }
  46. }
  47. ]
  48. }

批量查询  _msearch

使用match_all进行查询,并且只返回第一个文档。如果没有指定size的值,则默认返回前10个文档

也可以指定返回从哪个文档开始,返回多少文档.

took —— Elasticsearch执行这个搜索的耗时,以毫秒为单位

timed_out —— 指明这个搜索是否超时

_shards —— 指出多少个分片被搜索了,同时也指出了成功/失败的被搜索的shards的数量

hits —— 搜索结果

hits.total —— 能够匹配我们查询标准的文档的总数目

hits.hits —— 真正的搜索结果数据(默认只显示前10个文档)

Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD的更多相关文章

  1. Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation

    原文:Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. ...

  2. Elasticsearch7.X 入门学习第一课笔记----基本概念

    原文:Elasticsearch7.X 入门学习第一课笔记----基本概念 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https: ...

  3. Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍

    原文:Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本 ...

  4. Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板

    原文:Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接: ...

  5. Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer

    原文:Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处 ...

  6. Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介)

    原文:Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介) 版权声明:本文为博主原创文章,遵循CC 4.0 BY ...

  7. Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search)

    原文:Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...

  8. CI(CodeIgniter)框架入门教程——第二课 初始MVC

    本文转载自:http://www.softeng.cn/?p=53 今天的主要内容是,使用CodeIgniter框架完整的MVC内容来做一个简单的计算器,通过这个计算器,让大家能够体会到我在第一节课中 ...

  9. python学习第二次笔记

    python学习第二次记录 1.格式化输出 name = input('请输入姓名') age = input('请输入年龄') height = input('请输入身高') msg = " ...

随机推荐

  1. poj 3352 : Road Construction 【ebcc】

    题目链接 题意:给出一个连通图,求最少加入多少条边可使图变成一个 边-双连通分量 模板题,熟悉一下边连通分量的定义.最后ans=(leaf+1)/2.leaf为原图中size为1的边-双连通分量 #i ...

  2. CDMA原理

    CDMA原理——特点 CDMA具有抗多径干扰.抗窄带干扰.抗认为干扰.抗多径延迟扩展的能力.同时有提高蜂窝系统的通信容量和便于模拟与数字体制的共存与过渡等优点.与TDMA技术形成强劲的竞争力. 与FD ...

  3. SQL 介绍和操作

    1.什么是SQL SQL的全称是“结构话查询语句”(Structured Query Language ),是1974年有Boyce和chamberlin 提出来的.经过多年的发展,SQL语言已经成为 ...

  4. .NET(c#) 移动APP开发平台 - Smobiler(2) - 平台介绍

    看到大家很多人在后台问我一些问题,所以准备写一个系列了,下面给个目录 目录: .NET(c#) 移动APP开发平台 - Smobiler(1) 环境的搭建及上手第一个应用 类似开发WinForm的方式 ...

  5. Codeforces Round #603 (Div. 2) E. Editor

    E. Editor 题目链接: https://codeforces.com/contest/1263/problem/E 题目大意: 输入一个字符串S1含有‘(’ , ‘)’ , ‘R’ , ‘L’ ...

  6. document.referer

    参考文章: 深入理解document.referrer的用法

  7. [CSP-S模拟测试]:环(图论+期望)

    题目传送门(内部题79) 输入格式 第一行读入两个整数$n,e$表示节点数及$cwystc$已确定的有向边边数. 接下来$e$行,每行两个整数$x,y$描述$cwystc$确定的边. 输出格式 输出一 ...

  8. Linux网卡驱动分析

    以太网(Ethernet)是一种计算机局域网组网技术,基于IEEE 802.3标准,它规定了包括物理层的连线.电信号和介质访问层协议. Ethernet接口的实质是MAC通过MII总线控制PHY的过程 ...

  9. 爱好-超级IP:超级IP

    ylbtech-爱好-超级IP:超级IP  IP,是Intellectual Property的缩写,字面粗译为“知识产权”,特指具有长期生命力和商业价值的跨媒介内容运营.一个具有可开发价值的真正的I ...

  10. 运行jar包shell脚本

    #!/bin/sh #该文件必须放在jar包的目录下,因为是以相对路径来运行的.不放jar包目录的话,可以直接在jar_name参数写绝对路径 #start 设置三个参数 #环境 profile=te ...