V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
AmadeusZZZ
V2EX  ›  问与答

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

  •  
  •   AmadeusZZZ · May 25, 2022 · 1791 views
    This topic created in 1432 days ago, the information mentioned may be changed or developed.

    我的查询语句是这样的{ "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 replies    2022-05-26 23:28:56 +08:00
    AmadeusZZZ
        2
    AmadeusZZZ  
    OP
       May 25, 2022
    @pubby 我就是看了官方的文档,我这查询也没写错啊,但就是聚合没数据
    slzcz
        3
    slzcz  
       May 26, 2022
    这样?
    slzcz
        4
    slzcz  
       May 26, 2022
    @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
       May 26, 2022
    @slzcz 不行,会报错 runtime error 也不知道咋回事,感觉是 lastIndexOf 还有 substring 运行不了
    slzcz
        6
    slzcz  
       May 26, 2022
    @AmadeusZZZ 报 runtime error root_cause 不是有报错的信息麽?

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

    [![XZ6HgI.png]( https://s1.ax1x.com/2022/05/26/XZ6HgI.png)]( https://imgtu.com/i/XZ6HgI)
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1051 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 23:18 · PVG 07:18 · LAX 16:18 · JFK 19:18
    ♥ Do have faith in what you're doing.