当前位置: 首页 > news >正文

4. 条件查询

  首先区分下match,match_phrase,term,  参考:https://zhuanlan.zhihu.com/p/592767668?utm_id=0

1、全量查询+分页+指定source

示例:请求地址为http://127.0.0.1:9200/students/_search,请求体为:

{"query": {"match_all": {}},"from": 0,"size": 2,"_source": ["姓名","年级","班级"],"sort": {"班级": {"order": "desc"}}
}

  1. 请求体中的match_all表示匹配所有
  2. 请求体中from和size用于分页查询,from表示第一个元素的位置(从0开始),size表示要查询的数量。
  3. 请求体中_source是一个列表,指定要查询的列。
  4. 请求体中的sort用于结果排序,order取值asc(升序),desc(降序)
  5. 返回结果中的took表示查询耗时

2. 单条件查询

查询5年级的学生,请求body:

{"query": {"match": {"年级":5}}
}

  1. 请求体中match表示匹配一个条件

3. 多条件查询

3.1 基本多条件查询

3.1.1 多个条件同时匹配

查询5年级2班的学生,请求body:

{"query": {"bool": {"must": [{"match": {"年级": 5}},{"match": {"班级": 2}}]}}
}
  1. bool 表示一个条件,条件为true表示匹配,false表示不匹配,其下可以使用must,should,filter等多个条件。
  2. must可以设置多个条件,是一个数组,表示其下的条件必须全部匹配
  3. 把must改为should,表示其下的条件满足一个即可

3.1.2 满足至少一个条件

查找1班和2班的学生:

{"query": {"bool": {"should": [{"match": {"班级": 1}},{"match": {"班级": 2}}]}}
}

3.1.3 范围查询

   must表示多个条件同时满足,should表示至少匹配一个条件,filter表示过滤查询;范围使用range匹配(和match,match_all相同,指定具体条件)。

例如查询5年级1班和2班的学生:

{"query": {"bool": {"must": [{"match": {"年级": 5}}],"filter": {"range": {"班级": {"gte": 1,"lte": 2}}}}}
}

4. 分组查询(聚合查询)

{"aggs": {"班级分组": {"terms": {"field": "班级"}}}
}

更多的时候,我们只想要分组统计,不需要查询原始数据,可以设置查询size为0

{"aggs": {"班级分组": {"terms": {"field": "班级"}}},"size": 0
}
  1. 请求中的terms表示分组统计,其他的关键字还有:avg(对field指定的字段取平均值)
http://www.lryc.cn/news/180787.html

相关文章:

  • 【VIM】初步认识VIM-2
  • 《HelloGitHub》第 90 期
  • Apache Hudi初探(五)(与flink的结合)--Flink 中hudi clean操作
  • stream对list数据进行多字段去重
  • 一种基于体素的射线检测
  • 利用Docker安装Protostar
  • go基础语法10问
  • SpringCloud + SpringGateway 解决Get请求传参为特殊字符导致400无法通过网关转发的问题
  • vim基本操作
  • Drift plus penalty 漂移加惩罚Part1——介绍和工作原理
  • (四)动态阈值分割
  • jvm介绍
  • 数据结构与算法课后题-第三章(顺序队和链队)
  • SSM - Springboot - MyBatis-Plus 全栈体系(十六)
  • k8s--storageClass自动创建PV
  • 7.3 调用函数
  • 如果使用pprof来进行性能的观测和优化
  • 在移动固态硬盘上安装Ubuntu系统和ROS2
  • 【iptables 实战】02 iptables常用命令
  • webview_flutter
  • 【GESP考级C++】1级样题 闰年统计
  • CentOS密码重置
  • Tomcat Servlet
  • 国庆day2---select实现服务器并发
  • Grafana 开源了一款 eBPF 采集器 Beyla
  • 亲测可用国产GPT人工智能
  • 适配器模式详解和实现(设计模式 四)
  • IDEA的使用
  • CSS详细基础(二)文本样式
  • win10系统任务栏图标变成白色的解决办法