本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
EXP_AVG
EXP_AVG ( expression, <time-interval> )
EXP_AVG 返回在指定时间窗口内选择的值表达式的流的指数加权的平均值。EXP_AVG 基于 <time-interval> 的值将指定窗口分成若干个时间间隔。对于最近的时间间隔,指定表达式的值的加权最大,而对于较早的时间间隔,则加权指数级降低。
示例
此示例创建了 30 秒窗口内每个股票代码价格的指数加权平均值,这样最近 10 秒子窗口中的价格(该股票代码)的权重是中间 10 秒子窗口中价格权重的两倍,是中间 10 秒子窗口中价格权重的四倍最古老的 10 秒子窗口。
select stream t.rowtime, ticker, price, exp_avg(price, INTERVAL '10' SECOND) over w as avgPrice from t window w as (partition by ticker range interval '30' second preceding);
在此示例中,10 秒是衰减函数的半衰期,也就是说,应用于平均价格的权重在此期间减少了两倍。换句话说,较旧的重量将是新版本的一半。在调用 EXP_AVG 时,它被指定为 time_interval,间隔 “10” 秒。