Elasticsearch为开发者提供了一套基于Http协议的Restful接口,只需要构造rest请求并解析请求返回的json即可实现访问Elasticsearch服务器。Elasticsearch的API接口功能丰富,包含集群、监控、部署管理等,也包含常用的文档、索引操作,本文主要是使用Postman工具对文档操作相关的api做学习记录。

新增文档

PUT方式:http://localhost:9200/store/product/1  //指定id,存在则更新,不存在则新增

POST方式:http://localhost:9200/store/product   //自动生成id

其中store表示Index,product表示Type,数字1表示的是Document(文档)的主键,主键可以是任意的形式,也可以不指定主键,Elasticsearch将会自动生成一个唯一主键,但是必须是post方式提交请求。

测试:

返回结果中_id:自动生成的主键,_shards:表示分区信息,total:2表示有两个分区,successful:1 表示成功赋值了一份。_version:1表示该文档的版本号,每修改一次,版本号都会自增。

Elasticseach-head中查看数据:

根据主键查询

GET方式:http://localhost:9200/store/product/nMWgs2UBQISnN0EoTXZL   Elasticserach提供的是restful api,很容易理解这个接口形式。

返回结果中_source表示返回的Doucment(文档)类容,其他几个是Elasticsearch文档结构字段。如果只需要_source内容不需要其他结构字段,还可以在请求url上加上属性”/_source”,将只返回source部分容,请求:http://localhost:9200/store/product/1/_source

根据主键更新文档

在 Elasticsearch 中文档是 不可改变 的,不能修改它们。如果想要更新现有的文档,需要 重建索引或者进行替换,更新接口同新增文档接口,使用/index/type/key的形式。Elasticsearch的实现方式是将旧的文档标记为删除,并增加一个全新的文档。标记为删除的文档将不再可以直接操作,但它并不会立即消失,Elasticsearch会在后台清理这些已标记为删除的文档。

如果明确知道修改文档的哪部分数据,还可以通过在上述请求URL后面添加“/_update”并使用POST的方式,来更新数据,虽然这个看上去像是直接更新的,实际上也是重新创建了一个新的文档,处理过程为是先从就的文档中构建Json数据,并根据请求修改的字段修改json数据,然后将就文档标记为删除,添加一个新文档。请求如下:

如果并发修改文档,可以使用version字段实乐观锁,修改的目标文档的版本号version和传入的不一致,则会修改失败,请求url:http://localhost:9200/store/product/1/_update?version=4

根据主键删除

使用DELETE方式,请求格式 host/index/type/key

搜索文档

Elasticsearch提供了强大的搜索功能,搜索参数可以放在请求url上,也可以放在body中,请求基本格式: host/index/type/_search

  1. GET方式+ url参数的方式进行全文搜索

返回结果中_score是搜索引擎的概念,表示相关度,分数越高表示此文档与搜索条件关键字的匹配程度越高。

   2. 使用match表达式进行全文搜索

  3. elasticsearch也支持分页查询,使用from和size两个参数指定页码和页大小即可。

更详细的说明参考官方文档:

中文文档:https://www.elastic.co/guide/cn/elasticsearch/guide/current/index.html

英文文档:https://www.elastic.co/guide/en/elasticsearch/reference/6.4/index.html

最新文章

  1. Android获取网络图片
  2. 【转】 依赖注入框架Autofac的简单使用
  3. eclipse插件汇总
  4. 用phpcms开发模块时中文乱码问题
  5. FFmpeg-20160506-snapshot-bin
  6. mq队列管理器命令
  7. linux eval命令
  8. ASP.NET-FineUI开发实践-10
  9. Redis SAVE 命令 返回 ERR
  10. Kubuntu定制开始菜单
  11. app专项测试自动化测试方法思路与实现
  12. mydumper
  13. java aes CBC的填充方式发现
  14. 【尚学堂·Hadoop学习】MapReduce案例2--好友推荐
  15. 加sogou 和wps
  16. Swagger2使用参考
  17. 最近新明白的SQL小知识
  18. SQL优化实战之加索引
  19. Visual Studio Code必备插件
  20. Android4.1(Jelly Bean)API新特性尝鲜

热门文章

  1. 快速认识LinkIt 7697开发板
  2. 盒模型與BFC
  3. vue中-webkit-box-orient:vertical打包放到线上不显示
  4. ASP.NET的服务端验证(干货)
  5. sql中的制表符、换行符、回车符,问题
  6. gitlab在push代码的时候报错
  7. spark on yarn 资源调度(cdh为例)
  8. Lite OS学习之事件EVENT
  9. char和String 在jsp java代码中与jstl代码中的区别
  10. 查询表的大小(mysql)