ElasticSearch的几种检索方式

主要分为以下几种:

1、query string search :查询字符串搜索
2、query DSL :特定领域的语言
3、query filter : 过滤查询
4、full-text search :(全文检索)
5、phrase search :(短语搜索)
6、highlight search :(高亮搜索)

有那些不懂的可以查看《Elasticsearch 权威指南》:https://www.elastic.co/guide/cn/elasticsearch/guide/current/term-vs-full-text.html

搜索全部数据

http://localhost:9200/_search

took:耗费了几毫秒
timed_out:是否超时,这里是没有
_shards:数据拆成了5个分片,所以对于搜索请求,会打到所有的primary shard(或者是它的某个replica shard也可以)
hits.total:查询结果的数量,3个document
hits.max_score:score的含义,就是document对于一个search的相关度的匹配分数,越相关,就越匹配,分数也高
hits.hits:包含了匹配搜索的document的详细数据

查询索引下面的所有数据

http://localhost:9200/articleindex/_search

1.query string search的由来是因为,因为search参数都是以http请求query string 来附带参数的

比如搜索商品名称包含“欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士”

http://localhost:9200/goods/goodslist/_search?q=name:欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男

2、query DSL :Domain Specified Language,特定领域的语言

http request body:请求体,可以用json的格式来构建查询语法,比较方便,可以构建各种复杂的语法,比起第一种还是强大很多。

比如查询所有商品:

http://localhost:9200/goods/goodslist/_search

"query": { "match_all": {} }   //查询所有

body:

{
    "query":{
        "match":{
            "name":"欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士"
        }
    },
    "sort": [
        { "price": "desc" }
        
    ]
}

返回的查询信息如下:

分页查询:总共3条商品,假设每页就显示1条商品,现在显示第2页,所以就查出来第2个商品

{
  "query": { "match_all": {} },
  "from": 1,
  "size": 1
}

查询显示商品名字和价格字段数据:

{
    "query":{
        "match_all":{}
    },
    "_source":["name","price"]
}

3.query filter

搜索商品等于欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士 并且价格大于50元的商品

“bool”:代表布尔查询:https://www.cnblogs.com/xing901022/p/5994210.html 详解

postman只能post可以写body;

http://localhost:9200/goods/goodslist/_search

body:

{
    "query":{
        "bool":{
            "must":{
                "match":{
                    "name":"欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士"
                }
            },
            "filter":{
                "range":{
                    "price":{"gt":"50"}
                }
            }
        }
    }
}

在这里写下自己的理解must:它由一个或者多个子句组成,每个子句都有特定的类型。字句中的条件必须满足,

返回的文档必须满足must子句的条件,并且参与计算分值。

4、full-text search(全文检索)

http://localhost:9200/goods/goodslist/_search

body:

{
    "query" : {
        "match" : {
            "name" : "欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士"
        }
    }
}

name:这个里面的搜索项会被拆开一个一个的去倒排索引里卖弄一一匹配,只要能匹配上任意一个拆解后的单词就可以作为搜索结果返回。

5、phrase search(短语搜索)

跟全文检索相对应,
phrase search,要求输入的搜索串,必须在指定的字段文本中,完全包含一模一样的,才可以算匹配,才能作为结果返回

http://localhost:9200/goods/goodslist/_search
{
    "query" : {
        "match_phrase" : {
            "name" : "欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士"
        }
    }
}

只有一条是匹配的。


6、highlight search(高亮搜索结果)

http://localhost:9200/goods/goodslist/_search

{
    "query" : {
        "match" : {
            "name" : "欧尼杰夏季修身休闲裤男运动休闲简约薄款长裤男士"
        }
    },
    "highlight": {
        "fields" : {
            "name" : {}
        }
    }
}

*局部跟新

例子:

PUT http://localhost:9200/test_index/test_type/10
{
  "test_field1": "test1",
  "test_field2": "test2"
}

POST http://localhost:9200/test_index/test_type/10/_update
{
  "doc": {
    "test_field2": "updated test2"
  }
}

猜你喜欢

转载自blog.csdn.net/weixin_41244495/article/details/87776792