1、query string search
2、query DSL
3、query filter
4、full-text search
5、phrase search
6、highlight search
-----------------------------------------------------------------------------------
took:耗费了几毫秒
timed_out:是否超时,这里是没有
_shards:数据拆成了5个分片,所以对于搜索请求,会打到所有的primary shard(或者是它的某个replica shard也可以)
hits.total:查询结果的数量,3个document
hits.max_score:score的含义,就是document对于一个search的相关度的匹配分数,越相关,就越匹配,分数也高
hits.hits:包含了匹配搜索的document的详细数据 {
"took": 2,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"failed": 0
},
"hits": {
"total": 3,
"max_score": 1,
"hits": [
{
"_index": "ecommerce",
"_type": "product",
"_id": "2",
"_score": 1,
"_source": {
"name": "jiajieshi yagao",
"desc": "youxiao fangzhu",
"price": 25,
"producer": "jiajieshi producer",
"tags": [
"fangzhu"
]
}
},
{
"_index": "ecommerce",
"_type": "product",
"_id": "1",
"_score": 1,
"_source": {
"name": "gaolujie yagao",
"desc": "gaoxiao meibai",
"price": 30,
"producer": "gaolujie producer",
"tags": [
"meibai",
"fangzhu"
]
}
},
{
"_index": "ecommerce",
"_type": "product",
"_id": "3",
"_score": 1,
"_source": {
"name": "zhonghua yagao",
"desc": "caoben zhiwu",
"price": 40,
"producer": "zhonghua producer",
"tags": [
"qingxin"
]
}
}
]
}
} ------------------------------------------------------------------------------
1、query string search
搜索商品名称中包含yagao的商品,而且按照售价降序排序:GET
/ecommerce/product/_search?q=name:yagao&sort=price:desc 适用于临时的在命令行使用一些工具,比如curl,快速的发出请求,来检索想要的信息;但是如果查询请求很复杂,是很难去构建的
在生产环境中,几乎很少使用query string search ------------------------------------------------------------------------------
2、query DSL DSL:Domain Specified Language,特定领域的语言
http request body:请求体,可以用json的格式来构建查询语法,比较方便,可以构建各种复杂的语法,比query string search肯定强大多了 查询所有的商品 GET /ecommerce/product/_search
{
"query": { "match_all": {} }
} 查询名称包含yagao的商品,同时按照价格降序排序 GET /ecommerce/product/_search
{
"query" : {
"match" : {
"name" : "yagao"
}
},
"sort": [
{ "price": "desc" }
]
} 分页查询商品,总共3条商品,假设每页就显示1条商品,现在显示第2页,所以就查出来第2个商品 GET /ecommerce/product/_search
{
"query": { "match_all": {} },
"from": 1,
"size": 1
} 指定要查询出来商品的名称和价格就可以 GET /ecommerce/product/_search
{
"query": { "match_all": {} },
"_source": ["name", "price"]
} 更加适合生产环境的使用,可以构建复杂的查询 ------------------------------------------------------------------------
3、query filter 搜索商品名称包含yagao,而且售价大于25元的商品 GET /ecommerce/product/_search
{
"query" : {
"bool" : {
"must" : {
"match" : {
"name" : "yagao"
}
},
"filter" : {
"range" : {
"price" : { "gt" : 25 }
}
}
}
}
}
--------------------------------------------------------------------------
4、full-text search(全文检索)
先把搜索词拆分为单个词,然后再进行检索 GET /ecommerce/product/_search
{
"query" : {
"match" : {
"producer" : "yagao producer"
}
}
} ----------------------------------------------------------------------------
5、phrase search(短语搜索) 跟全文检索相对应,相反,全文检索会将输入的搜索串拆解开来,去倒排索引里面去一一匹配,只要能匹配上任意一个拆解后的单词,就可以作为结果返回
phrase search,要求输入的搜索串,必须在指定的字段文本中,完全包含一模一样的,才可以算匹配,才能作为结果返回 GET /ecommerce/product/_search
{
"query" : {
"match_phrase" : {
"producer" : "yagao producer"
}
}
} ----------------------------------------------------------------------------
6、highlight search(高亮搜索结果) GET /ecommerce/product/_search
{
"query" : {
"match" : {
"producer" : "producer"
}
},
"highlight": {
"fields" : {
"producer" : {}
}
}
}

  

最新文章

  1. MVVM大比拼之AngularJS源码精析
  2. 第十讲(LINQ)
  3. mybaits入门
  4. HttpClient使用方法(包括POST文件)
  5. zabbix实现原理及架构详解
  6. CSS基础(03)
  7. My97DatePicker 没有权限问题
  8. chrome console 调试xpath
  9. Java设计模式之(建造者模式)
  10. 【Ubuntu Desktop】安装主流桌面
  11. setjmp和longjmp用法
  12. session.save()返回值问题
  13. 微信小程序基础之表单Form的使用
  14. java开发工具STS的下载及安装
  15. mysql 数据可视化操作---Navicat安装及简单使用
  16. Session & Cookie小知识~
  17. macOS 系统 .DS_Store 文件详解
  18. spring cloud: Hystrix(七):Hystrix的断容器监控dashboard
  19. Beetl模板引擎入门教程
  20. Docker operation

热门文章

  1. zabbix3.0.4关于java服务端程序内存溢出的处理
  2. 使用Navicat Premium对mssql2008r2授权用户
  3. jquery load加载页面内ajax返回的div不能响应页面js的问题的解决方案
  4. 用strings命令查看kafka-log内容
  5. Renderscript图像处理
  6. [PHP] 链表数据结构(单链表)
  7. 【图的遍历】广度优先遍历(DFS)、深度优先遍历(BFS)及其应用
  8. python访问百度地图接口并返回信息
  9. Linux学习笔记(Ubuntu操作系统)之hadoop学习之路
  10. lldp学习