elasticsearch5.0使用RequestBody搜索接口
所属分类 elasticsearch
浏览量 1321
根据原文翻译整理
https://www.elastic.co/guide/en/elasticsearch/reference/5.0/search-request-body.html
The search request can be executed with a search DSL,
which includes the Query DSL, within its body.
Query DSL
https://www.elastic.co/guide/en/elasticsearch/reference/5.0/query-dsl.html
Query DSL 使用json格式
GET /twitter/tweet/_search
{
"query" : {
"term" : { "user" : "kimchy" }
}
}
Out of the above, the search_type and the request_cache must be passed as query-string parameters.
The rest of the search request should be passed within the body itself.
The body content can also be passed as a REST parameter named source.
search_type和request_cache必须作为查询字符串参数传递。
其余部分应该在body中传递
主体内容也可以作为一个名为source的REST参数传递
Both HTTP GET and HTTP POST can be used to execute search with body.
Since not all clients support GET with body, POST is allowed as well.
HTTP GET和HTTP POST都可以使用body执行搜索。
因为不是所有的客户端都支持GET with body,所以POST也是允许的。
Fast check for any matching docs
快速检查是否匹配到文档了
GET /_search?q=message:elasticsearch&size=0&terminate_after=1
if the query was terminated early, the terminated_early flag will be set to true in the response.
terminated_early
{
"from" : 0, "size" : 10,
"query" : {
"term" : { "user" : "kimchy" }
}
}
"sort" : [
{ "post_date" : {"order" : "asc"}},
"user",
{ "name" : "desc" },
{ "age" : "desc" },
"_score"
],
_score to sort by score 根据文档分数排序
_doc to sort by index order 根据文档索引顺序排序
_doc has no real use-case besides being the most efficient sort order.
So if you don’t care about the order in which documents are returned,
then you should sort by _doc. This especially helps when scrolling.
_doc除了是最有效的排序顺序之外,没有真正的用例。
因此,如果您不关心文档返回的顺序,那么应该按_doc排序。这在滚动时特别有用。
supports sorting by array or multi-valued fields.
数组和多个值字段的排序
min max avg sum
PUT /my_index/my_type/1?refresh
{
"product": "chocolate",
"price": [20, 4]
}
POST /_search
{
"query" : {
"term" : { "product" : "chocolate" }
},
"sort" : [
{"price" : {"order" : "asc", "mode" : "avg"}}
]
}
Missing Values
missing value can be set to _last, _first, or a custom value
By default, the search request will fail if there is no mapping associated with a field.
默认情况下,如果没有与字段关联的映射,搜索请求将失败。
"sort" : [
{ "price" : {"unmapped_type" : "long"} }
]
Script Based Sorting
基于脚本的排序
Geo Distance Sorting
geo distance sorting does not support configurable missing values
Lat Lon as Properties string geohash array
distance_type
sloppy_arc arc plane
_source field 筛选 过滤
"_source": false obj.* [ "obj1.*", "obj2.*" ] ["field1","field2"]
includes and excludes patterns
The stored_fields parameter is about fields that are explicitly marked as stored in the mapping,
which is off by default and generally not recommended.
If the requested fields are not stored (store mapping set to false), they will be ignored.
脚本字段
Script fields can work on fields that are not stored
script_fields
"test1" : {
"script" : {
"lang": "painless",
"inline": "doc['my_field_name'].value * 2"
}
}
使用doc仍然是访问文档值的推荐方法,因为每次使用_source时都必须加载和解析它。使用_source非常慢。
Doc value Fields
Doc value fields can work on fields that are not stored.
Note that if the fields parameter specifies fields without docvalues
it will try to load the value from the fielddata cache
causing the terms for that field to be loaded to memory (cached),
which will result in more memory consumption.
如果fields参数指定了没有docvalues的字段,它将尝试从fielddata缓存加载该值,
从而导致将该字段的词加载到内存(缓存)中,这将导致更多内存消耗。
Post filter
The post_filter is applied to the search hits at the very end of a search request,
after aggregations have already been calculated.
搜索结果过滤,在搜索执行之后再过滤
Allows to highlight search results on one or more fields.
lucene plain highlighter
the fast vector highlighter (fvh)
postings highlighter
Rescoring
Search Type
There are different execution paths that can be done when executing a distributed search.
The distributed search operation needs to be scattered to all the relevant shards
and then all the results are gathered back.
When doing scatter/gather type execution, there are several ways to do that,
specifically with search engines.
query_then_fetch
dfs_query_then_fetch
scroll
"explain": true
返回结果显示文档,默认为false
"version": true
上一篇
下一篇
elasticsearch5.0搜索API使用概述
elasticsearch5.0基于url的搜索接口
新东方年会《释放自我》歌词
科创板首批人工智能公司信息
CAP和一致性协议
MySQL基础架构