开发者社区 > 大数据与机器学习 > 实时计算 Flink > 正文

大佬们 为啥我这个sql开窗不出数啊

3765问.png

展开
收起
游客3oewgrzrf6o5c 2022-08-30 11:29:01 338 0
1 条回答
写回答
取消 提交回答
  • 全栈JAVA领域创作者

    根据您提供的截图,查询的结果集都是NULL值,这可能是由于您使用了错误的窗口规范或窗口边界导致的。

    在您的查询中,您定义了一个时间滚动窗口,并按照field1和field2进行分组聚合。但是,您没有指定窗口的起始和结束时间,因此Flink无法确定如何为数据分配到窗口中。

    请注意,对于滚动窗口,您需要通过指定窗口大小来定义窗口。例如,如果您想每隔10秒计算一次聚合结果,您可以使用以下语句:

    SELECT TUMBLE_END(ts, INTERVAL '10' SECOND), field1, field2, COUNT(*) FROM my_table GROUP BY TUMBLE(ts, INTERVAL '10' SECOND), field1, field2 在上面的示例中,我们使用TUMBLE()函数定义了一个10秒的滚动窗口,并在每个窗口中按照field1和field2进行分组聚合。

    请注意,我们还使用了TUMBLE_END()函数来指定窗口的结束时间。这样做是因为Flink默认情况下返回窗口的起始时间。如果您想要窗口的结束时间,您需要使用TUMBLE_END()函数。

    希望这可以帮助您解决问题!

    2023-06-06 23:34:30
    赞同 展开评论 打赏

实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。

相关电子书

更多
AnalyticDB基础版:云原生My SQL 敏捷数仓 立即下载
第十二届 BigData NoSQL Meetup — 基于hbase的New sql落地实践 立即下载
时序数据库TSDB的SQL与流计算 立即下载