eslasticsearch操做集锦

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

类型-type:一个类型是你的索引的一个逻辑上的分类/分区,其语义彻底由你来定。一般,会为具备一组共同字段的文档定义一个类型。好比说,咱们假设你运营一个博客平台而且将你全部的数据存储到一个索引中。在这个索引中,你能够为用户数据定义一个类型,为博客数据定义另外一个类型html

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

Node 与 Cluster:

Elastic 本质上是一个分布式数据库,容许多台服务器协同工做,每台服务器能够运行多个 Elastic 实例。node

单个 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字段表示命中的记
tooktimed_outhits
  • total:返回记录数,本例是2条。
  • max_score:最高的匹配程度,本例是1.0
  • hits:返回的记录组成的数组。

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

7 全文搜索数组

Elastic 的查询很是特别,使用本身的查询语法,要求 GET 请求带有数据体。bash

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

上面代码使用 Match 查询,指定的匹配条件是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

$ 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": "系统" } } ] } } }'
相关文章
相关标签/搜索