7.Elasticsearch请求体查询

本文介绍了Elasticsearch中的请求体查询方法,包括查询字符串、空查询、分页查询等核心概念。请求体查询能够更好地利用Elasticsearch的强大功能,支持片段强调、聚合分析和智能建议等功能。

本文目录:
- 请求体查询
- 空查询
- from 和size
- 注意get请求

请求体查询

轻量搜索 —query-string search— 对于用命令行进行即席查询(ad-hoc)是非常有用的。 然而,为了充分利用查询的强大功能,你应该使用 请求体 search API, 之所以称之为请求体查询(Full-Body Search),因为大部分参数是通过 Http 请求体而非查询字符串来传递的。

请求体查询 —下文简称 查询—不仅可以处理自身的查询请求,还允许你对结果进行片段强调(高亮)、对所有或部分结果进行聚合分析,同时还可以给出 你是不是想找 的建议,这些建议可以引导使用者快速找到他想要的结果。

空查询

空查询将返回所有索引库(indices)中的所有文档:

GET /_search

查询people索引下的user类型的所有文档:

GET people/user/_search

可以在一个、多个或者 _all 索引库(indices)和一个、多个或者所有types中查询:

GET people/user,teacher/_search

from 和size

分页会用到from 和size

GET people/user/_search
{
  "from": 0,
  "size": 2
}
注意get请求:

某些特定语言(特别是 JavaScript)的 HTTP 库是不允许 GET 请求带有请求体的。 事实上,一些使用者对于 GET 请求可以带请求体感到非常的吃惊。

而事实是这个RFC文档 RFC 7231— 一个专门负责处理 HTTP 语义和内容的文档 — 并没有规定一个带有请求体的 GET 请求应该如何处理!结果是,一些 HTTP 服务器允许这样子,而有一些 — 特别是一些用于缓存和代理的服务器 — 则不允许。

对于一个查询请求,Elasticsearch 的工程师偏向于使用 GET 方式,因为他们觉得它比 POST 能更好的描述信息检索(retrieving information)的行为。然而,因为带请求体的 GET 请求并不被广泛支持,所以 search API 同时支持 POST 请求:

POST people/user/_search
{
  "from": 0
  , "size": 2
}

类似的规则可以应用于任何需要带请求体的 GET API。

这种带请求体的语言,方便我们使用Query DSL 来写查询语句。

下一篇:8.Elasticsearch查询表达式Query DSL
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值