ElasticSearch URI 查询
公号:码农充电站pro
主页:https://codeshellme.github.io
1,URI 查询格式
URI 查询的一般格式如下:
GET /index_name/_search?q=key:val&df=title&sort=year:desc&from=0&size=10
{
"profile":"true"
}
其中的参数代表的含义如下:
- q:用于指定查询语句,它可以是一个键值对,也可以只有一个 val。
- key 表示在哪个字段中查询。
- val 表示查询的内容。
- df:查询中未定义字段前缀时使用的默认字段。如果不指定,默认会对所有字段进行查询。
- sort:指定排序规则。
- from:与 size 一起用于分页。
- profile:用于查看查询执行的详细过程,可参考这里。
- 更多的 URI 参数可参考这里。
2,范查询
如果查询时没有指定字段,就会在所有的字段中查询,这叫做范查询。例如 q=2012。
3,Term:单词查询
Term 查询不需要用引号引住。比如 q=A B 表示包含 A 或 B。
4,Phrase:词组查询
Phrase 查询需要用引号引住。
比如 q="A B",表示包含 "A B",并且要求顺序一致,实际上此时 "A B" 会被认为是一个单词。
5,查询分组
比如 q=title:A B,表示的是 title:A 或 B,会在 title 字段中查询 A,在所有的字段中查询 B。
而 q=title:(A B),只会在 title 中查询 A 或 B。(A B) 用括号括住,表示一个分组。
6,布尔查询
在使用 {"profile":"true"} 查看执行过程时,会有两个概念 must 和 must_not:
must:表示必须存在,用+表示。must not:表示必须不存在,用-表示。
布尔查询包含下面三种:
- AND:且,比如
q=title:(A AND B),表示+title:A +title:B,表示必须包含A,也必须包含B。 - OR:或,比如
q=title:(A OR B),等同于q=title:(A B),表示title:A title:B,表示title中包含A或包含B。 - NOT:非,比如
q=title:(A NOT B),表示title:A -title:B,表示包含A,但不能包含B。
也可以在查询中直接使用 + 或 -, + 用 %2B (URL 编码)表示,比如:
q=title:(%2BA -B),表示必须包含 A,不能包含 B。q=title:(-A -B),表示不能包含 A,也不能包含 B。q=title:(-A %2BB),表示不能包含 A,但必须包含 B。q=title:(A %2BB),其实等价于q=title:(%2BB),表示必须包含 B,A 无所谓。
7,范围查询
用于数字类型:
[]表示闭区间{}表示开区间
使用的时候用括号括住,比如:
year:({2000 TO 2020]),表示2000 < year <= 2020。year:([* TO 2018]),表示year <= 2018。year:({2016 TO *}),表示year > 2016。
8,通配符与正则查询
在通配符查询中:
?代表 1 个字符*代表 0 或多个字符
一般通配符查询效率较低,占内存大,所以不建议使用,特别是放在最前面。
通配符查询示例:
title:mi?dtitle:be*
正则表达式查询示例:
title:[bt]oy
9,模糊匹配与近似查询
示例:
title:beautifl~1title:"Lord Rings"~2
(本节完。)
推荐阅读:
Kibana,Logstash 和 Cerebro 的安装运行
欢迎关注作者公众号,获取更多技术干货。

ElasticSearch URI 查询的更多相关文章
- ElasticSearch DSL 查询
公号:码农充电站pro 主页:https://codeshellme.github.io DSL(Domain Specific Language)查询也叫做 Request Body 查询,它比 U ...
- Elasticsearch URI search 查询语法整理
Elasticsearch URI search 一.请求体查询与空查询 1. 请求体查询(request body search) 简单查询语句(lite)是一种有效的命令行adhoc查询.但是,如 ...
- 分布式搜索引擎Elasticsearch的查询与过滤
一.写入 先来一个简单的官方例子,插入的参数为-XPUT,插入一条记录. curl -XPUT 'http://localhost:9200/test/users/1' -d '{ "use ...
- 002_分布式搜索引擎Elasticsearch的查询与过滤
一.写入 先来一个简单的官方例子,插入的参数为-XPUT,插入一条记录. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 curl -XPUT 'http:/ ...
- 【转】elasticsearch的查询器query与过滤器filter的区别
很多刚学elasticsearch的人对于查询方面很是苦恼,说实话es的查询语法真心不简单- 当然你如果入门之后,会发现elasticsearch的rest api设计是多么有意思. 说正题,ela ...
- 基于百度地图SDK和Elasticsearch GEO查询的地理围栏分析系统(1)
本文描述了一个系统,功能是评价和抽象地理围栏(Geo-fencing),以及监控和分析核心地理围栏中业务的表现. 技术栈:Spring-JQuery-百度地图WEB SDK 存储:Hive-Elast ...
- Elasticsearch Kibana查询语法
Elasticsearch Kibana查询语法 2018年06月03日 23:52:30 wangpei1949 阅读数:3992 Elasticsearch Kibana Discover的搜 ...
- ElasticSearch—分页查询
ElasticSearch查询—分页查询详解 Elasticsearch中数据都存储在分片中,当执行搜索时每个分片独立搜索后,数据再经过整合返回.那么,如何实现分页查询呢? 按照一般的查询流程来说,如 ...
- Elasticsearch 邻近查询示例
Elasticsearch 邻近查询示例(全切分分词) JAVA API方式: SpanNearQueryBuilder span = QueryBuilders.spanNearQuery(); s ...
随机推荐
- python模块----sys模块 (系统相关的参数和函数)
pprint 模块:它给我们提供了一个方法 pprint() 该方法可以用来对打印的数据做简单的格式化 sys模块+pprint模块 标准库网址(sys):https://docs.python.or ...
- HDU-4315 Climbing the Hill
题目链接 先回到阶梯博弈的裸题中,比如POJ-1704,所有的块只能向左移并且不能跨越,这个向左移的结果我们可以理解为将左边的宽度减少使得右边的宽度增加,等同于阶梯模型中将石子从高阶移动到低阶.那么最 ...
- Codeforces Round #684 (Div. 2)【ABC1C2】
比赛链接:https://codeforces.com/contest/1440 A. Buy the String 题解 枚举字符串中 \(0\) 或 \(1\) 的个数即可. 代码 #includ ...
- ES中文分词器安装以及自定义配置
之前我们创建索引,查询数据,都是使用的默认的分词器,分词效果不太理想,会把text的字段分成一个一个汉字,然后搜索的时候也会把搜索的句子进行分词,所以这里就需要更加智能的分词器IK分词器了. ik分词 ...
- Base64 编码原理
什么是 Base64 编码 Base64 编码是最常见的编码方式,基于 64 个可打印字符来表示任意二进制数据的方法,是从二进制转换到可见字符的过程. 使用场景 数据加密或签名通过 Base64 转换 ...
- leetcode29 两数相除 int 与移位
难受啊 考虑越界 考虑dividend为-2^31,用负数移位运算 class Solution { public: int divide(int dividend, int divisor) { i ...
- 解决关闭ssh后网页停止服务的方法,利用nohup
上一篇文章提到宝塔面板无法运行,只能用ssh运行app.py. 关闭ssh时,app.py会被杀死.因为app.py的父进程就是ssh,关掉ssh会造成进程被杀死. 解决方法参考 https://w ...
- codeforces - 978D【思维】
D. Almost Arithmetic Progression time limit per test 1 second memory limit per test 256 megabytes in ...
- FZU2105 Digits Count(按位建线段树)题解
题意: 给出区间与.或.异或\(x\)操作,还有询问区间和. 思路: 因为数比较小,我们给每一位建线段树,这样每次只要更新对应位的答案. 与\(0\)和或\(1\)相当于重置区间,异或\(1\)相当于 ...
- SPOJ REPEATS Repeats (后缀数组 + RMQ:子串的最大循环节)题解
题意: 给定一个串\(s\),\(s\)必有一个最大循环节的连续子串\(ss\),问最大循环次数是多少 思路: 我们可以知道,如果一个长度为\(L\)的子串连续出现了两次及以上,那么必然会存在\(s[ ...