博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
eslasticsearch操作集锦
阅读量:5737 次
发布时间:2019-06-18

本文共 2641 字,大约阅读时间需要 8 分钟。

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

类型-type:一个类型是你的索引的一个逻辑上的分类/分区,其语义完全由你来定。通常,会为具有一组共同字段的文档定义一个类型。比如说,我们假设你运营一个博客平台并且将你所有的数据存储到一个索引中。在这个索引中,你可以为用户数据定义一个类型,为博客数据定义另一个类型

文档-document:一个文档是一个可被索引的基础信息单元。比如,你可以拥有某一个客户的文档,某一个产品的一个文档,当然,也可以拥有某个订单的一个文档。文档以JSON(Javascript Object Notation)格式来表示。许多条 Document 构成了一个 Index,可以是json格式

Node 与 Cluster:

Elastic 本质上是一个分布式数据库,允许多台服务器协同工作,每台服务器可以运行多个 Elastic 实例。

单个 Elastic 实例称为一个节点(node)。一组节点构成一个集群(cluster)。

 
健康检查: curl 'localhost:9200/_cat/health?v'
status:绿色代表一切正常(集群功能齐全),黄色意味着所有的数据都是可用的,但是某些复制没有被分配(集群功能齐全),红色则代表因为某些原因,某些数据不可用
 
节点查询:curl 'localhost:9200/_cat/nodes?v'
 
索引列表: curl 'localhost:9200/_cat/indices?v'
 
   1.新建和删除 Index
curl -X PUT 'localhost:9200/xxx'
curl -X DELETE 'localhost:9200/weather' 2新增记录
curl -X PUT 'localhost:9200/hupu/xxx/1' -d '{  "title": "怎么选?",  "readnum": "43243",  "likenum": "3124"}' id可以指定,可以不指定;id不一定是数字,也可以是字符串 3.查看记录
curl 'localhost:9200/hupu/xxx/1?pretty=true'
4删除记录
curl -X DELETE 'localhost:9200/hupu/xxx/1'
5更新记录
curl -X PUT 'localhost:9200/hupu/xxx/1' -d '{
"title": "怎么选?",  "readnum": "43243",  "likenum": "3124" }'
6返回所有记录
curl 'localhost:9200/hupu/xxx/_search'
took字段表示该操作的耗时(单位为毫秒),timed_out字段表示是否超时,hits字段表示命中的记
  • total:返回记录数,本例是2条。
  • max_score:最高的匹配程度,本例是1.0
  • hits:返回的记录组成的数组。

返回的记录中,每条记录都有一个_score字段,表示匹配的程序,默认是按照这个字段降序排列。

7 全文搜索

Elastic 的查询非常特别,使用自己的,要求 GET 请求带有数据体。

$ curl 'localhost:9200/accounts/person/_search'  -d '{  "query" : { "match" : { "desc" : "软件" }}}'

上面代码使用 ,指定的匹配条件是desc字段里面包含"软件"这个词。返回结果如下。

{  "took":3, "timed_out":false, "_shards":{ "total":5,"successful":5,"failed":0}, "hits":{ "total":1, "max_score":0.28582606, "hits":[ { "_index":"accounts", "_type":"person", "_id":"1", "_score":0.28582606, "_source": { "user" : "张三", "title" : "工程师", "desc" : "数据库管理,软件开发" } } ] } }

Elastic 默认一次返回10条结果,可以通过size字段改变这个设置。

$ curl 'localhost:9200/accounts/person/_search'  -d '{  "query" : { "match" : { "desc" : "管理" }},  "size": 1}'

上面代码指定,每次只返回一条结果。

还可以通过from字段,指定位移。

$ curl 'localhost:9200/accounts/person/_search'  -d '{  "query" : { "match" : { "desc" : "管理" }},  "from": 1,  "size": 1}'

上面代码指定,从位置1开始(默认是从位置0开始),只返回一条结果。

8逻辑运算

如果有多个搜索关键字, Elastic 认为它们是or关系。

$ curl 'localhost:9200/accounts/person/_search'  -d '{  "query" : { "match" : { "desc" : "软件 系统" }}}'

上面代码搜索的是软件 or 系统

如果要执行多个关键词的and搜索,必须使用。

$ curl 'localhost:9200/accounts/person/_search'  -d '{  "query": {    "bool": {      "must": [        { "match": { "desc": "软件" } },        { "match": { "desc": "系统" } }      ]    }  }}'
 
 

转载于:https://www.cnblogs.com/guixiaoming/p/8508941.html

你可能感兴趣的文章
软件定义存储之后,下一步考虑的是什么?
查看>>
IBM大数据深耕华南 激发数据价值
查看>>
SUSE全球联盟与营销的副总裁畅谈企业IT的未来趋势
查看>>
浅谈JavaScript中的异步处理
查看>>
LTE学习笔记(一)——背景知识
查看>>
突破媒体转码效率壁垒 阿里云首推倍速转码
查看>>
容器存储中那些潜在的挑战和机遇
查看>>
程序员该懂一点儿KPI
查看>>
<转载>在数据科学环境中使用 Docker 容器
查看>>
R语言的三种聚类方法
查看>>
55%受访企业将物联网战略视为有效竞争手段
查看>>
深入理解Python中的ThreadLocal变量(上)
查看>>
如果一切即服务,为什么需要数据中心?
查看>>
RSA总裁预测2016年网络安全趋势
查看>>
Spark架构在大数据环境的核心位置找到用武之地
查看>>
全球软件定义网络(SDN)市场调查分析
查看>>
想在Google做好外贸推广你得注意这些seo优化误区
查看>>
基于 Jenkins 快速搭建持续集成环境
查看>>
奥巴马最新“网络安全国家行动计划(CNAP)”要点概览
查看>>
存储性能101:服务器、阵列与网络架构基础
查看>>