您的位置:首页 > Web前端 > CSS

[ElasticsSearch] 排序(一)

2015-08-31 14:14 417 查看
排序是定义在字段级别的,可以通过定义根据特定字段的内容来规定排序规则

{
"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,这样分数就会被计算和跟踪。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: