1、之前三节讲述的都是索引结构及内容填充的部分,既然添加了数据那我们的目的无非就是增产改查crudp,我先来讲讲查询-----结构化查询

  我们看上图截图两种方式:

  1)第一种,在索引index5类型school下面定义一个查询query(这就是内嵌查询的关键字),query内部嵌套一个match根据指定field也就是字段查找其内容包含的关键字hawal。

  2)第二种,在索引index5类型school下面定义一个查询query(这就是内嵌查询的关键字),query内部嵌套一个match_all,不指定任何字段任何条件,就相当于查询所有内容,相当于GET /index5/school/_search

 

2、复杂嵌套查询

  在关系型数据库中有很多条件判断,比如 等于=  不等于!=等等,在es中同样有相应解决方案:

  1)must  需要满足条件  ==或like

  2)must_not  不需要在满足条件内的 !=或 not like

  我们举例查询,在索引index5中查询满足条件name字段包含hawal的,id字段不是12开头或包含12的,写成sql大概是where name like '%hawal%' and id not like '%12%'

  es中是这么表达的,同样定义一个query查询嵌套块,里面定义一个bool(和query一样是es内嵌关键字)的嵌套,name字段must为hawal,id字段must_not为12的。

  

3、term过滤

  注意哦,这里是精确匹配,大小写什么都很严格,我们查询/index5索引下,name值为hawal或Hawal的查询有两种结果,请看:

  

  看上图,索引中name存的是"Hawal",我们用Hawal"精准"的去匹配匹配不到,用hawal去匹配反而匹配到了,这是为什么呢?因为索引这行数据的时候分析其默认帮我们全转换成了小写,所以大写H开头的Hawal搜索不到,这,不知道是我理解有误还是es这么做有其他原理?

    

4、terms过滤(多值匹配)

  

5、range过滤

  上图查询索引index5下subject下id大于或等于1002的所有内容

  范围操作符包含:

        

6、exists和missing过滤

  exists 和 missing 过滤可以用于查找文档中是否包含指定字段或没有某个字段,类似于SQL语句中的 IS_NULL 条件

  我们举个例子,查找索引index5下name字段不为空的内容

  

  其实就是指定field(字段)去查name字段不为空的内容,missing就不举例了。

 

7、bool过滤

  见本篇第二小节,must,must_not,should

 

8、match_all语句

  GET /index5/_search
  {
    "query": {
      "match_all": {}
      }
  }

  其实就相当于GET /index5/_search

9、带过滤的查询语句

  如我现在精确匹配索引index5下name包含mit的内容

  GET /index5/_search
  {
    "query":{
    "term":{
      "subject.subject-name":"computer"
       }
    }
  }

  但是我同时向加入另一条过滤,在匹配subject.subject-name包含"computer"的同时还需要过滤subject.students大于1002的内容

  

  

  我们看上图执行结果,索引/index5中subject.subject-name字段匹配computer的内容,然后过滤掉里面subject.students大于1002的内容,这里所有结果的students都小于1002,所以均返回了。

  那我们可以很好的理解query和filter的区别,query是现实匹配的,filter是在已匹配的内容里面过滤掉满足fiter条件的内容。

  请注意------es 5.x往后的版本去掉了filters语法,统一采用bool嵌套filter的语法。

10、验证查询

  有时候我们写了一个查询语句,但是可能由于语法错误或指定查询的字段不存在报了一堆错误,但是提示信息并不明显,这时es给我们提供了一个校验请求语法的功能,其实就是在执行前先会帮忙校验一下语法是否正确,并会给出相关提示信息:

  比如我要查询索引index5下所有name字段中包含“tinghua”的内容,但这是我把内嵌查询query字段拼成了qery,这时就该提示Unknown key for a START_OBJECT in [qery]。

  

  其实,我们可以先对查询体做校验,在请求体后加上/_validate/query即可:

  

 

  可以看到右边的校验结果为false,想看到更具体的结果,加上?explain即可

  

 

  如果校验成功,我们会看到es的索引结果,如你用的分析器将你需要搜索的内容拆分成几个字段,在哪些索引中查找到内容都能看到:

  

 

elasticsearch结构化查询过滤语句-----4的更多相关文章

  1. ElasticSearch 常用的查询过滤语句

    query 和  filter 的区别请看: http://www.cnblogs.com/ghj1976/p/5292740.html Filter DSL term 过滤 term主要用于精确匹配 ...

  2. [转] ElasticSearch 常用的查询过滤语句

    备忘remark https://www.cnblogs.com/ghj1976/p/5293250.html query 和  filter 的区别请看: http://www.cnblogs.co ...

  3. ElasticSearch 基本概念 and 索引操作 and 文档操作 and 批量操作 and 结构化查询 and 过滤查询

    基本概念 索引: 类似于MySQL的表.索引的结构为全文搜索作准备,不存储原始的数据. 索引可以做分布式.每一个索引有一个或者多个分片 shard.每一个分片可以有多个副本 replica. 文档: ...

  4. ElasticSearch 5学习(10)——结构化查询(包括新特性)

    之前我们所有的查询都属于命令行查询,但是不利于复杂的查询,而且一般在项目开发中不使用命令行查询方式,只有在调试测试时使用简单命令行查询,但是,如果想要善用搜索,我们必须使用请求体查询(request ...

  5. ElasticSearch(6)-结构化查询

    引用:ElasticSearch权威指南 一.请求体查询 请求体查询 简单查询语句(lite)是一种有效的命令行_adhoc_查询.但是,如果你想要善用搜索,你必须使用请求体查询(request bo ...

  6. ElasticSearch权威指南学习(结构化查询)

    请求体查询 简单查询语句(lite)是一种有效的命令行adhoc查询.但是,如果你想要善用搜索,你必须使用请求体查询(request body search)API. 空查询 我们以最简单的 sear ...

  7. SQL结构化查询语句

    SQL结构化查询语句 SQL定义了查询所有关系型数据库的规则. 1.通用语法 SQL语句可以单行或者多行书写,以分号结尾 可以使用空格和缩进增强可读性 不区分大小写,但是关键字建议大写 3种注释 注释 ...

  8. Elasticsearch 结构化搜索、keyword、Term查询

    前言 Elasticsearch 中的结构化搜索,即面向数值.日期.时间.布尔等类型数据的搜索,这些数据类型格式精确,通常使用基于词项的term精确匹配或者prefix前缀匹配.本文还将新版本的&qu ...

  9. ElasticSearch 结构化搜索

    1.介绍 结构化搜索(Structured search) 是指有关探询那些具有内在结构数据的过程.比如日期.时间和数字都是结构化的:它们有精确的格式,我们可以对这些格式进行逻辑操作. 比较常见的操作 ...

随机推荐

  1. echarts设置地图大小比例,大小设置

    设置地图大小可通过以下属性设置: geo.aspectScale number [ default: 0.75 ] 这个参数用于 scale 地图的长宽比. 最终的 aspect 的计算方式是:geo ...

  2. Java编码思想之什么是高内聚低耦合?

    分别描述的是模块内部特征,和模块外部引用关系. 内聚就是一个模块内各个元素彼此结合的紧密程度,高内聚就是一个模块内各个元素彼此结合的紧密程度高. 内聚是就其中任何一个模块的内部特征而言的. 耦合是就多 ...

  3. python web开发之flask框架学习(2) 加载模版

    上次学习了flask的helloword项目的创建,这次来学习flask项目的模版加载: 第一步:创建一个flask项目 第二步:在项目目录的templates文件夹下创建一个html文件 第三步: ...

  4. jmeter+Jenkins性能测试自动化搭建

    一.安装java.ant.maven 1.官网下载tar.gz包 2.解压相应的tar包 3.配置/etc/profile路径 4.source /etc/profile 使配置生效. 二.安装Jen ...

  5. PAT天梯赛L1-054 福到了

    题目链接:点击打开链接 "福"字倒着贴,寓意"福到".不论到底算不算民俗,本题且请你编写程序,把各种汉字倒过来输出.这里要处理的每个汉字是由一个 N x N 的 ...

  6. Arch下systemd无法开机执行rc.local之解决方法

    早就发现了,Arch的systemd提供的那个 rc-local.service 貌似有问题,rc.local不会执行.因为没用rc.local,一直没管. 解决方法源自这里,需要稍加改动: http ...

  7. SQL-Error-1

    错误描述:String   or   binary   data   would   be   truncated. 原因:字段长度不够

  8. P1445 [Violet]樱花

    传送门 看到题目就要开始愉快地推式子 原式 $\frac{1}{x}+\frac{1}{y}=\frac{1}{n!}$ $\rightarrow \frac{x+y}{xy}=\frac{1}{n! ...

  9. CF .Beautiful numbers 区间有多少个数字是可以被它的每一位非零位整除。(数位DP)

    题意:数字满足的条件是该数字可以被它的每一位非零位整除. 分析:大概的思路我是可以想到的 , 但没有想到原来可以这样极限的化简 , 在数位dp 的道路上还很长呀 : 我们都知道数位dp 的套路 , 核 ...

  10. css animation fade in

    <html> <style> @-webkit-keyframes fadeIn{0%{opacity:0}100%{opacity:1}} @-o-keyframes fad ...