排序是定义在字段级别的,可以通过定义根据特定字段的内容来规定排序规则
{
"sort" : [
{ "post_date" : {"order" : "asc"}}, ------定义在字段级别排序的多种方式
"user",
{ "name" : "desc" },
{ "age" : "desc" },
"_score"
],
"query" : {
"term" : { "user" : "kimchy" }
}
}
一、想要根据字段内容的长度来排序
"sort": [
{
"_script": {
"script": "doc['field_name'].values[0].length() * factor",
"type": "number",
"params": {
"factor": 1
},
"order": "asc"
}
}
]
从而结果中就会按照该字段内容的长度排序,长度越短的排在前面.
我们直接运行可能会出错,1.6以后为了安全,es才禁用使用脚本语言。因此需要在配置文件中添加如下语句
在yml中加上一点东西,:script.disable_dynamic: false ,并且经过尝试只能放在配置文件的末端,
还未验证但是放在其他的地方并没起到作用。因此不追究其原因,先放在末端,跑起来再说。
后补:最后发现不是这个位置的原因,而是修改之后必须重启es服务器,而当时有两个用户一起登陆,
导致一个用户的重启服务器失效。总而言之,加上这个语句然后再重启服务器即可。
借用师傅的一句话:技术的积累总是潜移默化和反复的过程中增长
因此不气馁,反复中求得真知!
二、根据字段内容排序(中文规则,拼音首字母排序)
目前默认的只支持英文字母排序,中文排序不是想要的结果.需要安装插件,待完善。
注:当使用排序_sort 来指定依据某些字段排序。就不会计算得分,需要设置"track_scores":true,这样分数就会被计算和跟踪。