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代码实现

相关推荐
RealmElysia3 小时前
CoAlbum 引入ES
java·elasticsearch
失散1315 小时前
分布式专题——43 ElasticSearch概述
java·分布式·elasticsearch·架构
望获linux19 小时前
【实时Linux实战系列】实时 Linux 的自动化基准测试框架
java·大数据·linux·运维·网络·elasticsearch·搜索引擎
风清再凯20 小时前
01-ELK安装ES,ES-head
大数据·elk·elasticsearch
JAVA学习通1 天前
SpringOJ竞赛项目----组件ElasticSearch
大数据·elasticsearch·搜索引擎
xxxxxxllllllshi1 天前
Java中Elasticsearch完全指南:从零基础到实战应用
java·开发语言·elasticsearch·面试·职场和发展·jenkins
失散132 天前
分布式专题——47 ElasticSearch搜索相关性详解
java·分布式·elasticsearch·架构
铭毅天下2 天前
Elasticsearch 到 Easysearch 数据迁移 5 种方案选型实战总结
大数据·elasticsearch·搜索引擎·全文检索
Elastic 中国社区官方博客2 天前
Elasticsearch 推理 API 增加了开放的可定制服务
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索