ES 查询一,基于URL 的查询

开始查询

GET {index}								# 1. 查看,索引结构
GET {index}/_search						# 2. 查看,索引的所有数据。(ES 查询使用 _search 关键字)
GET {index}/_doc/08010312012022000094 	# 3. 查看,索引的一条数据。(ID 查询使用 _doc关键字)

一、ES 查询概述

1.1 语法

GET /{index}/_search
POST /{index}/_search

1.2 模式(URL、DSL)

  • URI Search , 基于URL 的查询语法的 GET模式查询。
  • DSL Search , 基于DSL 语言的查询的POST模式查询。( Request Body Search 请求体搜索 )

1.3 目标(index)

查询目标可以是一个索引,也可以是多个索引

命令说明
/_search在所有索引上搜索
/index1/_search在 index1 索引上搜索
/index1,index2/_search在 index1 , index2 索引上搜索
/index*/_search在 index 开头的索引上搜索
/g*,user*/_search在任何以 g 或者 u 开头的索引中搜索所有的类型
/gb/user/_search在 gb 索引中搜索 user 类型
/gb,us/user,tweet/_search在 gb 和 us 索引中搜索 user 和 tweet 类型
/_all/user,tweet/_search在所有的索引中搜索 user 和 tweet 类型

二、URL Search

基于URL 的查询方式

2.1 URL查询,语法

2.1.1 精简

GET /index1/_search?q=2012&df=title&sort=year:desc&from=0&size=10&time1s
{"profile"true}

# 参数详解
- q ,查询字符串
- df  ,default_field 默认查询那个字段
	-  默认为index.query.default_field,即未指定字段前缀时返回所有字段,索引设置为* 
- sort ,排序。
	- fieldName 可以是实际字段,也可以是特殊_score名称,表示基于分数的排序。
	- 可以有几个sort参数(顺序很重要)。
	- fieldName 
	- fieldName:asc
	- fieldName:desc。
- from  , 分页,位置(默认0)。
- size  , 分页,数量(默认10)。
- {"profile"true} 查询执行细节(调试用)

2.1.2 详解

// URL 语法 ,注意要用''包起来,否则后面的&会被识别为“后台执行”,即&后面的内容被忽略
curl [ -s][ -g][ -X<REST>][ -H 'Content-Type: application/json'] '<IP>:<Port>/<Index>[/Type][/ID]/_search?pretty&q=<search string>'
  
  -s 不输出查询的时间那些东西
  -g 做转义用  
  <REST>GET/POST/PUT
  <IP>:<port>IP+端口号,<port> 默认80ES默认9200
  <Index> , 索引名,支持通配符,power_json*
  <Type>  , 索引类型,由于一个index只有一个type,可不输入
  <ID> , 操作对象的ID号,可不输入
  q  ,查询字符串,前面加&,后跟查询语句

// 常用参数
- _source_include ,查询包含某些source字段的文档。
- _source_exclude , 查询不包含某些source字段的文档。
timeout---搜索超时,将搜索请求限制在指定的时间值内执行,并使用在到期时累积的点击数进行保释。默认为无超时。
- default_operator , 默认查询运算符,未指定时默认为OR- analyzer , 用于分析查询字符串的分析器名称。
- _source , 设置为false禁用_source字段检索。
- analyze_wildcard 是否应分析通配符和前缀查询,默认为false


// 常用语法
- status:active , status字段包含 active
	- status 字段名 
	- active 值
	- “:”,代替了“=- title:(quick OR brown)
	- where the title field contains quick or brown. If you omit the OR operator the default operator will be used
- author:"John Smith"---where the author field contains the exact phrase "john smith"
_exists_:title---where the field title has any non-null value
- date:[2012-01-01 TO 2012-12-31]---All days in 2012
- count:[10 TO *]---Numbers from 10 upwards
- count:>=10---Numbers from 10 upwards

2.2 单字段、多字段、所有字段

在字段 title 中,查询 “2012“ 关键词

GET /{index}/_search?q=title:2012 		# 单字段
GET /{index}/_search?q=2012&df=title 	# 单字段
GET /{index}/_search?pretty&q=age:14&q=name:c2_59 	# 多字段, SQL 语句: age="14" and name="c2_59" 
GET /index1/_search?q=2012 # 所有字段、泛查询,在所有字段查询“2012“ 关键词.

2.3 逻辑、范围

2.4.1 逻辑

- title:(matrix  NOT reloaded)
- title:(+matrix -reloaded)
修饰符(必须大写)符号写法(说明)URLEncoding
AND&&
OR||
NOT!
+must%2B
-must_not

2.4.2 范围

year: {2019 TO 2018} # 开区间
year:[* TO 2018] # 闭区间
year: >2010
year:(>2010 && <=2018)
year:(+>2010 && +<=2018)
GET /movies/_search?q=year:>=1980  # 电影需要在 1980 年后
区间说明
[]闭区间
{}开区间

2.4 其他

2.4.1 空格

# 在字段 title 中,查询 “Beautiful Mind“ 关键词 
GET /index1/_search?q=title:(Beautiful Mind) 

例:
```URL
GET /index1/_search?q=title:(Beautiful AND Mind) 

在字段 title 中,必须包含“Beautiful” 和 "Mind“ 两个关键词

GET /index1/_search?q=title:(Beautiful NOT Mind) 

在字段 title 中,必须包含“Beautiful” 剔除关键词 ,不能包含 "Mind“

2.4.5 通配符

GET /movies/_search?q=title:b*   # 模糊匹配
	 
GET /movies/_search?q=title:beautifl~1  # 近似查询,可以对单词纠错,并找到结果 

GET /movies/_search?q=title:"Lord Rings"~2 # 可以查询所有包含 ”Lorad .... Rings “ 模式的结果

三 URL Search 例子

curl 'localhost:9200/_cat/indices?v&s=index'    //s=sort排序    
curl 'localhost:9200/_cat/indices/power_json*?v&s=index'  //只查power_json
curl 'localhost:9200/_cat/allocation?v&s=node'  //获取集群的节点列表
curl 'localhost:9200/power_json*?pretty'   //pretty,美观
curl 'localhost:9200/power_json*/_search?pretty&q=_exists_:MULT'     //是否存在
curl 'localhost:9200/power_json*/_search?pretty&q=TESTID:10000000107326732674'   //查指定的字段值
curl 'localhost:9200/power_json*/_search?pretty&q=TESTID:10000000107326732674&size=3' //查指定的字段值,并只显示3个
curl 'localhost:9200/power_json*/_search?pretty&q=TESTID:10000000107326732674&from=2&size=3' //从第3个开始只显示3个,即3/4/5
curl 'localhost:9200/power_json*/_search?pretty&q=TESTID:10000000107326732674&sort=TIME:desc' //按时间排序,desc降序,默认为升序
curl 'localhost:9200/power_json*/_search?pretty&analyze_wildcard&q=TESTID:10000000107326732674'   //模糊查询
curl 'localhost:9200/power_json*/_search?pretty&q=VAL:<200'  //比较大小
curl 'localhost:9200/power_json*/_search?pretty&_source=false'  //是否显示
curl 'localhost:9200/power_json*/_search?pretty&_source_includes=TIME,VAL'  //设置包含的字段
curl -g 'localhost:9200/power_json*/_search?pretty&q=(SOLAR:1%20AND%20CENTRAL:1)'  //组合查询
curl -g 'localhost:9200/power_json*/_search?pretty&q=TIME:[2019-05%20TO%202019-06]' //范围查询

DSL Search

  • https://blog.csdn.net/snake1900/article/details/109897409

其他

查询相关度 Information Retrieval

  • Precision (查准率) - 尽可能返回较少的无关文档
  • Recall(查全率) - 尽量返回较多的相关文档
  • Ranking - 是否能够按照相关读进行排序

参考

  • https://www.jianshu.com/p/46372a2df051
  • https://www.cnblogs.com/daynote/p/11076965.html
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Elasticsearch 查询语句可以使用 Query DSL 进行构建。以下是一些常见的查询语句示例: 1. 匹配查询:用于匹配一个特定字段中的值。 ``` GET /_search { "query": { "match": { "title": "elasticsearch" } } } ``` 2. 短语查询:用于匹配一个特定字段中的短语。 ``` GET /_search { "query": { "match_phrase": { "title": "elasticsearch tutorial" } } } ``` 3. 范围查询:用于匹配一个特定字段中的数值范围。 ``` GET /_search { "query": { "range": { "age": { "gte": 18, "lte": 30 } } } } ``` 4. 布尔查询:用于组合多个查询条件。 ``` GET /_search { "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" } }, { "match": { "description": "tutorial" } } ] } } } ``` 5. 聚合查询:用于对结果进行聚合计算。 ``` GET /_search { "aggs": { "avg_age": { "avg": { "field": "age" } } } } ``` 以上仅是一些常见的查询语句示例,Elasticsearch 还支持许多其他类型的查询。请参阅官方文档以了解更多信息。 ### 回答2: Elasticsearch 是一个开源的分布式搜索和分析引擎,它提供了强大的查询功能来检索和分析大量的数据。 Elasticsearch 查询语句可以使用 JSON 格式来构建,主要分为两种类型:查询查询语句和过滤查询语句。 查询查询语句用于根据特定的条件从索引中检索文档。常见的查询类型包括匹配查询、多字段查询、范围查询和布尔查询等。匹配查询用于在指定字段中搜索指定的词语,多字段查询可以在多个字段中搜索相同的词语,范围查询支持按照范围来搜索结果,而布尔查询则可以通过逻辑运算符组合多个查询条件。 过滤查询语句用于根据特定的条件过滤文档。与查询查询语句不同的是,过滤查询不会计算相关度分数,只关心是否匹配。常见的过滤查询类型有 term 过滤、范围过滤和 bool 过滤等。term 过滤用于精确匹配一个词语,范围过滤用于按照指定范围过滤结果,bool 过滤则可以通过逻辑运算符组合多个过滤条件。 除了查询和过滤,Elasticsearch 还支持一些聚合函数(aggregations),用于对搜索结果进行统计和分析。聚合查询可以对结果集进行分组、排序、计算总和、平均值等操作,从而提供更丰富的数据分析功能。 总之,Elasticsearch 查询语句是非常灵活和强大的,可以根据不同的需求组合不同的查询和过滤条件,实现高效的数据检索和分析。 ### 回答3: Elasticsearch是一个开源的分布式搜索和分析引擎,提供了强大的查询功能。查询语句是用户用来向Elasticsearch发送请求并获取结果的指令。 Elasticsearch查询语句可以分为两种,一种是基于URI的查询语句,另一种是基于请求体的查询语句。 基于URI的查询语句通常用于简单的查询请求,语法类似于URL。例如,要查询名为"products"的索引下的所有文档,可以使用以下查询语句: GET /products/_search 基于请求体的查询语句更为灵活,可以实现更复杂的查询功能。请求体是一个JSON对象,包含了查询的参数和条件。以下是一个常见的基于请求体的查询语句示例: POST /products/_search { "query": { "match": { "name": "手机" } } } 上述查询语句使用了"match"查询,指定了要查询的字段为"name",查询的关键词为"手机"。这将返回所有名为"手机"的文档。 此外,Elasticsearch还提供了许多其他类型的查询语句,包括布尔查询、范围查询、模糊查询等。用户可以根据需要选择合适的查询语句以实现精确的搜索结果。 总之,Elasticsearch查询语句是通过URI或请求体来发送查询请求的指令,使用不同类型的查询语句可以实现不同的搜索功能。用户可以根据自己的需求选择合适的查询语句,并通过分析返回的结果来满足他们的搜索和分析需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值