1、相关性排序

    ElasticSearch为了按照相关性来排序,需要将相关性表示为一个数值,在 Elasticsearch 中, 相关性得分 由一个浮点数进行表示,并在搜索结果中通过 _score 参数返回, _score 降序。

GET /index_china/fulltext/_search
{
  "query": {
    "match": {
      "name": "小张"
    }
  }
}

    ElasticSearch 排序

 

  2、按照字段排序

    有时,按照相关性评分排序并没有意义,下面的例子通过年龄来对 name 进行排序是有意义的,按照年龄排序,可以使用 sort 参数进行实现:

    

GET /index_china/fulltext/_search
{
  "query": {
    "match": {
      "name": "小张"
    }
  },
  "sort":  "age"
}

    默认是按照年龄升序

    ElasticSearch 排序

    

    下面是安装年龄降序

GET /index_china/fulltext/_search
{
  "query": {
    "match": {
      "name": "小张"
    }
  },
  "sort": { "age": { "order": "desc" }}
}

    ElasticSearch 排序

 

   3、多级排序

    用 age 和 _score 进行查询,并且匹配的结果首先按照年龄排序,然后按照相关性排序

GET /index_china/fulltext/_search
{
  "query": {
    "match_all": {}
  },
  "sort":[ {"age":{"order":"asc"}},
  {"_score":{"order":"desc"}}]
    
}

    ElasticSearch 排序

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-05-20
  • 2021-08-25
  • 2022-12-23
  • 2022-02-13
  • 2022-01-24
  • 2022-12-23
猜你喜欢
  • 2021-07-10
  • 2022-01-03
  • 2021-12-08
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-20
相关资源
相似解决方案