V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
AmadeusZZZ
V2EX  ›  问与答

有 Elasticsearch 大佬吗,我想问问我的查询语句哪出错了。我用 script 把 ip 字段的值截取到第三位,然后我想聚合去重,结果就是聚合里的桶没有数据

  •  
  •   AmadeusZZZ · 2022-05-25 19:58:06 +08:00 · 1050 次点击
    这是一个创建于 695 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我的查询语句是这样的{ "size": 0, "script_fields": { "ip_field": { "script": { "lang": "painless", "source": "def ips = doc['SourceIp'].value;def last=ips.lastIndexOf('.');return ips.substring(0,last);" } } }, "aggs":{ "ip_c":{ "terms":{ "field":"ip_field" } } } } 结果就是 script_fields 里的语句生效了,下面的 aggs 没有生效

    6 条回复    2022-05-26 23:28:56 +08:00
    AmadeusZZZ
        2
    AmadeusZZZ  
    OP
       2022-05-25 21:14:31 +08:00
    @pubby 我就是看了官方的文档,我这查询也没写错啊,但就是聚合没数据
    slzcz
        3
    slzcz  
       2022-05-26 00:17:39 +08:00
    这样?
    slzcz
        4
    slzcz  
       2022-05-26 00:17:54 +08:00
    @slzcz {
    "size": 0,
    "aggs": {
    "ip_c": {
    "terms": {
    "script": "def ips = doc['SourceIp'].value;def last=ips.lastIndexOf('.');return ips.substring(0,last);"
    }
    }
    }
    }
    AmadeusZZZ
        5
    AmadeusZZZ  
    OP
       2022-05-26 22:23:51 +08:00
    @slzcz 不行,会报错 runtime error 也不知道咋回事,感觉是 lastIndexOf 还有 substring 运行不了
    slzcz
        6
    slzcz  
       2022-05-26 23:28:56 +08:00
    @AmadeusZZZ 报 runtime error root_cause 不是有报错的信息麽?

    我本地模拟了一下,不知道是不是需要这样的效果,我的版本是 7.10.2

    [![XZ6HgI.png]( https://s1.ax1x.com/2022/05/26/XZ6HgI.png)]( https://imgtu.com/i/XZ6HgI)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1105 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 23:16 · PVG 07:16 · LAX 16:16 · JFK 19:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.