es query_string 和 match 的区别
默认使用 空格拆分成 多个 子项,并且 每个子项 都会去分词 查询。可以通过 default_operator 指定 子项之间的关系。默认是 或 。 然后 每个 子项前面可以使用 -+ 指定必须有 或者必须么有。并且 加了修饰符 +- 的 提出单独算。
测试数据:
{
"took": 4523,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"skipped": 0,
"failed": 0
},
"hits": {
"total": 4,
"max_score": 1,
"hits": [
{
"_index": "test01",
"_type": "doc",
"_id": "2",
"_score": 1,
"_source": {
"name": "zhang san"
}
},
{
"_index": "test01",
"_type": "doc",
"_id": "4",
"_score": 1,
"_source": {
"name": "张玉坤"
}
},
{
"_index": "test01",
"_type": "doc",
"_id": "1",
"_score": 1,
"_source": {
"name": "zhang yu kun"
}
},
{
"_index": "test01",
"_type": "doc",
"_id": "3",
"_score": 1,
"_source": {
"name": "li san"
}
}
]
}
}
"query": "zhang san",
"default_operator": "OR" 可以查询 有 zhang 或者 san 的 。
"query": "zhang +san",
"default_operator": "OR" 查询出 必须有san 可以有zhang 的 数据。( 有修饰符的 是提出来优先算的,剩下的在算 或关系 。并且 或中至少要有一个 ),因为只剩一个or 所以这个 zhang 必须有 。所有就是 有 zhang 有 san
"query": "zhang -san",
"default_operator": "OR" 查询 必须没有san ,剩下 or 只有一个zhang 所以这个zhang 必须瞒住。所以就是 必须有zhang ,但是必须没有san
"query": "张三",
"default_operator": "OR" 依旧可以查到张玉坤,所以 是分词的。 分词以后是或 关系。并且+- 的修饰只能出现在词头。不能出现在词中
"query": "张三",
"default_operator": "AND" 这个就什么都查询不到了。说明 default_operator 对分词以后的term 生效。
加一个
PUT /test01/doc/5
{
"name":"kun bo"
}
"query_string": {
"query": "zhang bo -san" 这时候查询出了新添加的那条 ,所以 没有 san , zhang 和 bo 带一个就可以。
"query_string": {
"query": "zhang bo +san" 这按照我的猜想应该是 必须有 san , zhang bo 有一个 。但是 却 可以 zhang bo 都没有。 这个就不知道为啥了,姑且 当做 es 的 一个bugger 吧。
在说说 mach 查询 。mach 查询只是 分词以后查询。相当于 query_string 空格 隔开的 一个子项。
es query_string 和 match 的区别的更多相关文章
- js正则表达test、exec和match的区别
test的用法和exec一致,只不过返回值是 true false. 以前用js很少用到js的正则表达式,即使用到了,也是诸如邮件名称之类的判断,网上代码很多,很少有研究,拿来即用. 最近开发遇到一些 ...
- 转转转---js正则表达exec与match的区别说明
正则表达式对象有两个定义方式:: 1.第一种定义: new RegExp(pattern, attributes);如var reg = new RegExp("abc",&quo ...
- 正则search与match的区别
import re # #1.search和match的区别 # pattern = re.compile(r'\d+') # #match从头开始匹配 # m = pattern.match('on ...
- es match、match_phrase、query_string和term的区别
(一)text字段和keyword字段的区别 以下给出一个例子: 首先建立一个索引和类型,引入一个keywork的字段: PUT my_index { "mappings": { ...
- ES查询-match VS match_phrase
我们以一个查询的示例开始,我们在student这个type中存储了一些学生的基本信息,我们分别使用match和match_phrase进行查询. 首先,使用match进行检索,关键字是“He is”: ...
- term&match得区别 text&keyword区别
Text 概念 Text 数据类型被用来索引长文本,比如说电子邮件的主体部分或者一款产品的介绍.这些文本会被分析,在建立索引前会将这些文本进行分词,转化为词的组合,建立索引.允许 ES来检索这些词语. ...
- ES PS TS 流的区别
http://fengqing888.blog.163.com/blog/static/330114162012111805717584/ ES是原始码流,包含视频.音频或数据的连续码流.TS是传输流 ...
- JavaScript中正则表达式test()、exec()、match() 方法区别
1.test test 返回 Boolean,查找对应的字符串中是否存在模式.var str = "1a1b1c";var reg = new RegExp("1.&qu ...
- js正则函数中test和match的区别
test是RegExp的方法,参数是字符串,返回值是boolean类型. match是String的方法,参数是正则表达式,返回值是数组. <script type="text/jav ...
随机推荐
- centos安装pip扩展包
1.安装 epel-release扩展yum源# yum install -y epel-release# yum clean all# yum makecache2.安装setuptools# yu ...
- 多进程于多线程的区别,cpu密集型适合用什么
多线程:在单个程序中同事运行多少个线程完成不同的工作,成为线程. 线程共享内存空间,进程的内存是独立的, 同一个进程的线程间可以直接交流: 两个进程想通信,必须通过一个中间代理来实现, 一个线程可以控 ...
- pycharm 永久解封
第一步 c:\windows\system32\drivers\etc 命令行输入这个 第二步 把host文件复制到桌面 第三步 记事本打开host 第四步 在最下面添加 ...
- python中字符串的操作方法
python中字符串的操作方法大全 更新时间:2018年06月03日 10:08:51 作者:骏马金龙 我要评论这篇文章主要给大家介绍了关于python中字符串操作方法的相关资料,文中通过示例代码详细 ...
- 关于selenium实现滑块验证
关于selenium实现滑块验证 python2.7+selenium2实现淘宝滑块自动认证参考链接:https://blog.csdn.net/ldg513783697/article/detail ...
- python 读写、创建 文件的方法(必看)
python 读写.创建 文件的方法(必看) 更新时间:2016年09月12日 10:26:41 投稿:jingxian 我要评论下面小编就为大家带来一篇python 读写.创建 文件的方法(必看). ...
- JAVA将单词首字母大写方法
public class FirstLetterUppercase { public static void main(String[] args){ System.out.println(new F ...
- maven项目中的pom.xml
需要配置的内容 1.配置头(自动生成) 2.maven项目的坐标(自动生成) <modelVersion>4.0.0</modelVersion> <groupId> ...
- DG备库缺失归档文件GAP日志
问题现象: XXXsdgebus-dg GAP手工注册归档 #出现GAP idle>select * from v$archive_gap; THREAD# LOW_SEQUENCE# HIGH ...
- 在 Mac 安装Docker
https://blog.csdn.net/jpiverson/article/details/50685817 https://legacy.gitbook.com/book/yeasy/docke ...