3. 基本使用姿势
ElasticSearch 基本使用姿势,如常见的
- 添加文档
- 常见的查询姿势
- 修改/删除文档
1. 添加文档
首次添加文档时,若索引不存在会自动创建; 借助kibana的dev-tools
来实现es的交互
POST first-index/_doc
{
"@timestamp": "2021-03-31T01:12:00",
"message": "GET /search HTTP/1.1 200 1070000",
"user": {
"id": "YiHui",
"name": "一灰灰Blog"
},
"addr": {
"country": "cn",
"province": "hubei",
"city": "wuhan"
},
"age": 18
}
## 添加两个数据进行测试
POST first-index/_doc
{
"@timestamp": "2021-03-31T02:12:00",
"message": "GET /search HTTP/1.1 200 1070000",
"user": {
"id": "ErHui",
"name": "二灰灰Blog"
},
"addr": {
"country": "cn",
"province": "hubei",
"city": "wuhan"
},
"age": 19
}
当然也可以直接使用http进行交互,下面的方式和上面等价(后面都使用kibanan进行交互,更直观一点)
curl -X POST 'http://localhost:9200/first-index/_doc?pretty' -H 'Content-Type: application/json' -d '
{
"@timestamp": "2021-03-31T01:12:00",
"message": "GET /search HTTP/1.1 200 1070000",
"user": {
"id": "YiHui",
"name": "一灰灰Blog"
},
"addr": {
"country": "cn",
"province": "hubei",
"city": "wuhan"
},
"age": 18
}'
data:image/s3,"s3://crabby-images/d3b20/d3b20671d94c7e2f58046a6de83469774a5daf39" alt=""
2. 查询文档
2.0 kibana配置并查询
除了基础的查询语法之外,直接使用kibana进行查询,对于使用方而言,门槛最低;首先配置上面的es索引
- Management -> Stack Management -> Kiabana Index Patterns
- index pattern name
- 时间字段,选择
@timestamp
这个与实际的文档中的field有关
data:image/s3,"s3://crabby-images/8a84c/8a84c4a60d07abbcc3662c0eba029d913af5bea0" alt=""
data:image/s3,"s3://crabby-images/924f9/924f94aba79832206e424a260086a0b7f6d23f63" alt=""
data:image/s3,"s3://crabby-images/d4198/d419831df2aa03c3a5b1ebb05149af9dcf213f67" alt=""
data:image/s3,"s3://crabby-images/761cb/761cbe3984abb8e26b27fe61d5dedbc88f7977da" alt=""
接下来进入Discover
进行查询
data:image/s3,"s3://crabby-images/a7619/a7619b1a4403247e3ec967da0489ca915b484d2d" alt=""
比如字段查询
data:image/s3,"s3://crabby-images/7296e/7296e32cec1b75e7a277812cf9a43d9c64484642" alt=""
2.1 查询所有
不加任何匹配,捞出文档(当数据量很多时,当然也不会真的全部返回,也是会做分页的)
GET my-index/_search
{
"query": {
"match_all": {
}
}
}
data:image/s3,"s3://crabby-images/0b6a3/0b6a3b3402a7a28a31be14f21386798fe1c7981b" alt=""
2.2 term精确匹配
根据field进行value匹配,忽略大小写;
查询语法,形如: {"query": {"term": {"成员名": {"value": "查询值"}}}}
query
,term
,value
三个key为固定值成员名
: 为待查询的成员查询值
: 需要匹配的值
(说明:后面语法中,中文的都是需要替换的,英文的为固定值)
GET first-index/_search
{
"query": {
"term": {
"user.id": {
"value": "yihui"
}
}
}
}
data:image/s3,"s3://crabby-images/0442d/0442d18022d6c2ca462c55e7cf862723ba557dd5" alt=""
当value不匹配,或者查询的field不存在,则查不到的对应的信息,如
data:image/s3,"s3://crabby-images/42138/421387b1df608ee0afe300cbf2530c5bc0dcc46e" alt=""
2.3 terms 多值匹配
term表示value的精确匹配,如果我希望类似value in (xxx)
的查询,则可以使用terms
语法:
{
"query": {
"terms": {
"成员名": [成员值, 成员值]
}
}
}
实例如
GET first-index/_search
{
"query": {
"terms": {
"user.id": ["yihui", "erhui"]
}
}
}
data:image/s3,"s3://crabby-images/2a5f9/2a5f9012ff42ba342ed9de053a5fd91f15d055fd" alt=""
2.4 range 范围匹配
适用于数值、日期的比较查询,如常见的 >, >=, <, <=
查询语法
{
"query": {
"range": {
"成员名": {
"gte": "查询下界" ,
"lte": "查询下界"
}
}
}
}
范围操作符 | 说明 |
---|---|
gt | 大于 > |
gte | 大于等于 >= |
lt | 小于 < |
lte | 小于等于 <= |
实例如下
GET first-index/_search
{
"query": {
"range": {
"age": {
"gte": 10,
"lte": 18
}
}
}
}
data:image/s3,"s3://crabby-images/4f4ff/4f4ff2cfd5f6c76724b689345c39dcd11ac75ed6" alt=""
2.5 字段过滤
根据是否包含某个字段来查询, 主要有两个 exists
表示要求存在, missing
表示要求不存在
查询语法
{
"query": {
"exists/missing": {
"field": "字段值"
}
}
}
实例如下
GET first-index/_search
{
"query": {
"exists": {
"field": "age"
}
}
}
data:image/s3,"s3://crabby-images/f25d8/f25d80739c71880856fc25cd10457cdb0707e73c" alt=""
2.6 组合查询
上面都是单个查询条件,单我们需要多个查询条件组合使用时,可以使用bool + must/must_not/should
来实现
查询语法
{
"query": {
"bool": {
"must": [ # 相当于and查询
"查询条件1",
"查询条件2"
],
"must_not": [ # 多个查询条件相反匹配,相当与not
...
],
"should": [ # 有一个匹配即可, 相当于or
...
]
}
}
}
实例如下
## user.id = yihui and age < 20
GET first-index/_search
{
"query": {
"bool": {
"must": [
{
"term": {
"user.id": {
"value": "yihui"
}
}
},
{
"range": {
"age": {
"lt": 20
}
}
}
]
}
}
}
# !(user.id) = yihui and !(age>20)
GET first-index/_search
{
"query": {
"bool": {
"must_not": [
{
"term": {
"user.id": {
"value": "yihui"
}
}
},
{
"range": {
"age": {
"gt": 20
}
}
}
]
}
}
}
# user.id = 'yihui' or age>20
GET first-index/_search
{
"query": {
"bool": {
"should": [
{
"term": {
"user.id": {
"value": "yihui"
}
}
},
{
"range": {
"age": {
"gt": 20
}
}
}
]
}
}
}
下面截图以 must_not 输出示意
data:image/s3,"s3://crabby-images/f0134/f013407b942f55ae2a149ac5cea3ab65adc056f0" alt=""
说明
- 前面根据字段查询
existing
只能单个匹配,可以借助这里的组合来实现多个的判断
2.7 match查询
最大的特点是它更适用于模糊查询,比如查询某个field中的字段匹配
语法
{
"query": {
"match": {
"字段名": "查询值"
}
}
}
举例说明
GET first-index/_search
{
"query": {
"match": {
"user.name": "灰og"
}
}
}
data:image/s3,"s3://crabby-images/0edcf/0edcf7f14fe5704d6ceb60613615b3c6ff2f4682" alt=""
说明,如果有精确查询的需求,使用前面的term,可以缓存结果
2.8 multi_match查询
更多相关信息,可以查看: 官网-multi_match查询
多个字段中进行查询
语法
- type:
best_fields
、most_fields
和cross_fields
(最佳字段、多数字段、跨字段) - 最佳字段 :当搜索词语具体概念的时候,比如 “brown fox” ,词组比各自独立的单词更有意义
- 多数字段:为了对相关度进行微调,常用的一个技术就是将相同的数据索引到不同的字段,它们各自具有独立的分析链。
- 混合字段:对于某些实体,我们需要在多个字段中确定其信息,单个字段都只能作为整体的一部分
{
"query": {
"multi_match": {
"query": "Quick brown fox",
"type": "best_fields",
"fields": [ "title", "body" ],
"tie_breaker": 0.3,
"minimum_should_match": "30%"
}
}
}
实例演示
GET first-index/_search
{
"query": {
"multi_match": {
"query": "汉",
"fields": ["user.id", "addr.city"]
}
}
}
data:image/s3,"s3://crabby-images/eab83/eab832ed82576123e3e655addd8796d146219d3c" alt=""
上面除了写上精确的字段之外,还支持模糊匹配,比如所有字段中进行匹配
GET first-index/_search
{
"query": {
"multi_match": {
"query": "blog",
"fields": ["*"]
}
}
}
2.9 wildcard查询
shell统配符
?
: 0/1个字符*
: 0/n个字符
GET first-index/_search
{
"query": {
"wildcard": {
"user.id": {
"value": "*Hu?"
}
}
}
}
说明,对中文可能有问题
2.10 regexp查询
正则匹配
GET first-index/_search
{
"query": {
"regexp": {
"user.name": ".*log"
}
}
}
2.11 prefix查询
前缀匹配
GET first-index/_search
{
"query": {
"prefix": {
"user.name": "一"
}
}
}
2.12 排序
查询结果排序,根据sort来指定
{
"sort": [
{
"成员变量": {
"order": "desc"
}
}
]
}
实例如下
GET first-index/_search
{
"query":{
"match_all": {}
},
"sort": [
{
"@timestamp": {
"order": "desc"
}
}
]
}
2.13 更多
更多操作姿势,可以在官方文档上获取
3. 删除文档
需要根据文档id进行指定删除
DELETE first-index/_doc/gPYLh3gBF9fSFsHNEe58
data:image/s3,"s3://crabby-images/e7976/e7976d8504e2b086490a306d97299a8320db51a2" alt=""
删除成功
data:image/s3,"s3://crabby-images/ceec7/ceec76426f686ae37becc269d3b9afc8c9f85bdd" alt=""
4.更新文档
4.1 覆盖更新
使用PUT来实现更新,同样通过id进行
- 覆盖更新
- version版本会+1
- 如果id对应的文档不存在,则新增
PUT first-index/_doc/f_ZFhngBF9fSFsHNte7f
{
"age": 28
}
data:image/s3,"s3://crabby-images/1cb0c/1cb0c9d664ad5683840f78fc9ef410180feaab65" alt=""
4.2 增量更新
采用POST来实现增量更新
- field 存在,则更新
- field不存在,则新增
POST first-index/_update/gvarh3gBF9fSFsHNuO49
{
"doc": {
"age": 25
}
}
data:image/s3,"s3://crabby-images/07b8e/07b8e5a658b12c806030a133d0cb23ba182cd5ef" alt=""
此外还可以采用script脚本更新
- 在原来的age基础上 + 5
POST first-index/_update/gvarh3gBF9fSFsHNuO49
{
"script": "ctx._source.age += 5"
}