具体脚本语法搜索“Groovy”语法
GET m_cyber_es_account/account/_search
{
"query": {
"term": {
"site_type_id": {
"value": "2"
}
}
},
"sort": [
{
"_script":{
"script":{
"inline": "doc['friends_num'].value + doc['fans_number'].value"
},
"type":"number",
"order": "desc"
}
}
]
}
Java API
SearchRequestBuilder facebookNodeAccountSearch = ESUtils.getClient().prepareSearch(Constants.INDEX_ACCOUNT).setTypes(Constants.TYPE_ACCOUNT);
facebookNodeAccountSearch.setQuery(QueryBuilders.termsQuery("account_id", facebookAccountIDs));
Script script = new Script("doc['friends_num'].value + doc['fans_number'].value"); //自定义脚本排序,粉丝数+好友数
ScriptSortBuilder sortBuilder = SortBuilders.scriptSort(script,ScriptSortBuilder.ScriptSortType.NUMBER).order(SortOrder.DESC);
facebookNodeAccountSearch.addSort(sortBuilder);
SearchHit[] facebookNodeAccountHits = facebookNodeAccountSearch.get().getHits().getHits();