源文档:
文档1:
{
“groupName”: “北京的俱乐部”,
“deleted”: 0,
“groupId”: “g1”,
“allowAccess”: 1,
“notice”: “介绍”
}
文档2:
{
“groupName”: “北京的俱乐部”,
“deleted”: 0,
“groupId”: “g2”,
“allowAccess”: 1,
“notice”: “介绍”
}
文档3:
{
“groupName”: “北京的俱乐部”,
“deleted”: 0,
“groupId”: “g3”,
“allowAccess”: 1,
“notice”: “介绍”
}
自定义排序规则:
我们希望g1排序最前面,依次是g2,g3
脚本代码:
// 定义脚本
String scriptText =" def groupScore = params.groupMap[doc['groupId.keyword'].value];" +
"groupScore != null?groupScore:0;";
// 自定义评分规则
Map<String,Float> groupMap = new HashMap<>();
groupMap.put("g1",3.0f);
groupMap.put("g2",6.0f);
groupMap.put("g3",9.0f);
Map<String, Object> params = new HashMap<>();
params.put("groupMap", groupMap);
Script script = new Script(ScriptType.INLINE,"painless",scriptText,params);
ScriptSortBuilder sortBuilder = SortBuilders.scriptSort(script,ScriptSortBuilder.ScriptSortType.NUMBER).order(SortOrder.DESC);
SearchResponse sr=srb
.setQuery(boolQueryBuilder)
.addSort(sortBuilder)
.addSort("_score", SortOrder.DESC)
.highlighter(highlightBuilder)
.setFrom(from).setSize(size)
.execute()
.actionGet();
说明:
1.doc[‘groupId.keyword’].value中的groupId为文档属性
2.若输入为字符串需加上.keyword取值
3.若为数值可用doc[‘deleted’].value取值
4.painless默认为params参数
5.painless中map取值用中括号[],如:params.groupMap[‘g1’]
6.若出现多个
.addSort(sortBuilder)
.addSort("_score", SortOrder.DESC)
优先以第一个排序