ES使用script进行复杂排序

es数据字段,关注_source内容,为自定义的es表字段内容

java 复制代码
{
    "clerk_id": 3150036230,
    "clerk_follow_status": 60,
    "create_time": 1729156110000,
    "channel": 1,
    "mid": 1538020071,
    "binlog_timestamp": null,
    "clue_tag": 0,
    "is_sync": 1,
    "vuid": 199603942960332807,
    "idempotence": "8101929dc442442b847a46fa09fa1c11",
    "sync_operation_time": 1733448887759,
    "follow_time": 1729230615000,
    "update_time": 1729230615000,
    "follow_count": 1,
    "id": 12428,
    "spu_id": 8797,
    "org_code": "MI0101",
    "wecom_friend": [
        3150036230
    ],
    "latest_purchase_time": 1656489614
}

要实现的排序逻辑是:如果wecom_friend字段包含指定id则优先排序

第一步 ,百度参考:Elasticsearch-script 脚本排序-CSDN博客

当前参考是字段==比较,那我们的是数组,则直接使用contains方法尝试

java 复制代码
{
    "_script": {
        "script": {
            "source": "if(params['_source']['wecom_friend'].contains('3150036230')){1}else{0}",
            "lang": "painless"
        },
        "type": "number",
        "order": "desc"
    }
}

执行可以看到,并没有匹配到

第二步,当前字段为long类型,所以是不是要去掉引号

执行报错

提示错误,需要改成long类型数字去匹配

第三步,修改后,执行成功

最终查询代码

java 复制代码
{
    "_script": {
        "script": {
            "source": "if(params['_source']['wecom_friend'].contains(3150036230L)){1}else{0}",
            "lang": "painless"
        },
        "type": "number",
        "order": "desc"
    }
}

Java代码实现

相关推荐
芜丶湖2 小时前
Vulhub靶机 Apache Druid(CVE-2021-25646)(渗透测试详解)
搜索引擎·网络安全·apache·activemq·安全性测试
平凡君9 小时前
ElasticSearch查询指南:从青铜到王者的骚操作
大数据·elasticsearch·搜索引擎
songbaoxian10 小时前
ElasticSearch
java·linux·elasticsearch
易安杰13 小时前
ElasticSearch+Kibana通过Docker部署到Linux服务器中
linux·elasticsearch·搜索引擎·全文检索·中文分词
m0_7482475513 小时前
重学SpringBoot3-整合 Elasticsearch 8.x (二)使用Repository
大数据·elasticsearch·jenkins
liupan688916 小时前
文档检索服务平台
elasticsearch·全文检索·开源软件
m0_7482486516 小时前
SpringBoot整合easy-es
spring boot·后端·elasticsearch
m0_7482563417 小时前
重学SpringBoot3-整合 Elasticsearch 8.x (一)客户端方式
大数据·elasticsearch·jenkins
LaughingZhu19 小时前
PH热榜 | 2025-02-23
前端·人工智能·经验分享·搜索引擎·产品运营