[ElasticsSearch] 排序(一)

来源:互联网 发布:买网络教育本科多少钱 编辑:程序博客网 时间:2024/05/17 08:40

排序是定义在字段级别的,可以通过定义根据特定字段的内容来规定排序规则

{    "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,这样分数就会被计算和跟踪。

1 0
原创粉丝点击