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 ...
随机推荐
- 牛客多校第四场 G Maximum Mode
链接:https://www.nowcoder.com/acm/contest/142/G来源:牛客网 The mode of an integer sequence is the value tha ...
- Java语法基础学习DayThree
一.流程控制语句补充 1.switch语句 格式: switch(表达式) { case 值1: 语句体1; break; case 值2: 语句体2; break; ... default: 语句体 ...
- python selenium爬取QQ空间方法
from selenium import webdriver import time # 打开浏览器 dr = webdriver.Chrome() # 打开某个网址 dr.get('https:// ...
- Python用户交互
print("开始") # 赋值,把等号右边的内容赋值给左边 s = input() #input("这里是input")# input输入,让用户输入一些内容 ...
- 【Python】unittest-2-断言
Unittest中的断言 1. python unintest单元测试框架提供了一整套内置的断言方法. (1)如果断言失败,则抛出一个AssertionError,并标识该测试为失败状态 (2)如果 ...
- 目录文件管理及vim
一.查看(七种看) cat tac nl more less ====================== head tail tail -f 看动态更新尾部的信息 ================= ...
- 交换机的默认网关(跨网段telnet)
实验要求:配置一台交换机,并配置默认网关,使不同网段的主机能够远程telnet连接到交换机 拓扑图如下: 交换机配置: enable 进入特权模式 configure terminal 进入全局模式 ...
- 生成式模型 VS 判别式模型
1 定义 1.1 生成式模型 生成式模型(Generative Model)会对x和y的联合分布p(x,y)建模,然后通过贝叶斯公式来求得 p(yi|x),然后选取使得p(yi|x) 最大的 yi,即 ...
- 操作cookie篇
1.设置cookie setcookie(key,value); 2.设置cookie有效期(默认值0,浏览器关闭失效,PHP_INT_MAX最大值,永久不失效,time()-1,删除cookie) ...
- 怎样用CMD命令强行删除文件?
如果你要删除的整个文件夹以及文件夹里面的所有内容的话rd/s/q 盘符:\某个文件夹 (这样整个文件夹所有的文件和文件夹都删除了)比如我想删除D盘的123文件夹以及123文件夹里面所有的内容rd/ ...