Elasticsearch - Text字段排序

插入数据

DELETE /website

PUT /website
{
  "mappings": {
    "properties": {
      "title": {
        "type": "text"
      }
    }
  }
}

PUT /website/_doc/1
{
  "title": "first class"
}
PUT /website/_doc/2
{
  "title": "second class"
}
PUT /website/_doc/3
{
  "title": "third class"
}

GET /website/_search
{
  "query": {
    "match_all": {}
  },
  "sort": [
    {
      "title": {
        "order": "desc"
      }
    }
  ]
}

默认情况下在基于title 排序时会报错,解决方案:

1. title设置 fielddata=true

DELETE /website

PUT /website
{
  "mappings": {
    "properties": {
      "title": {
        "type": "text",
        "fielddata": true
      }
    }
  }
}

PUT /website/_doc/1
{
  "title": "first class"
}
PUT /website/_doc/2
{
  "title": "second class"
}
PUT /website/_doc/3
{
  "title": "third class"
}

GET /website/_search
{
  "query": {
    "match_all": {}
  },
  "sort": [
    {
      "title": {
        "order": "desc"
      }
    }
  ]
}

此时可以根据title倒序查询,但可以看出是通过title的第一个分词来排序的
但是想让整个title字段排序就需要

2. 将一个text字段建立两次索引,一个用于搜索一个用于排序

# 设置一个keyword类型的属性
PUT /website
{
  "mappings": {
    "properties": {
      "title": {
        "type": "text",
        "fields": {
          "keyword": {
            "type": "keyword"
          }
        }
      }
    }
  }
}
# 查询时使用 title.keyword 查询 此时就是按照keyword进行排序
PUT /website/_doc/4
{
  "title": "second art"
}

GET /website/_search
{
  "query": {
    "match_all": {}
  },
  "sort": [
    {
      "title.keyword": {
        "order": "asc"
      }
    }
  ]
}

posted @   py卡卡  阅读(113)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
点击右上角即可分享
微信分享提示