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"
}
}
]
}
分类:
Elasticsearch
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧