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

上游一个update事件,同样的flink -sql处理,在本地调试是delete+insert。在

上游一个update事件,同样的flink -sql处理,在本地调试是delete+insert。在阿里云rds看到的却是update,有人遇到过这个情况吗?

展开
收起
游客3oewgrzrf6o5c 2022-08-15 10:45:49 570 0
1 条回答
写回答
取消 提交回答
  • 全栈JAVA领域创作者

    这种情况可能是由于阿里云RDS的更新操作与Flink-SQL的处理方式不同导致的。在Flink-SQL中,当使用update语句时,它会先删除旧的数据,然后再插入新数据。但是,在阿里云RDS中,更新操作可能会直接修改现有的数据,而不是删除旧数据并插入新数据。因此,您在本地调试时看到的是delete+insert,而在阿里云RDS中看到的是update。

    如果您需要确保在阿里云RDS中看到与本地调试相同的结果,请尝试使用upsert语句来替换update语句。upsert语句会尝试插入新数据,如果数据已经存在,则会更新现有数据。这样可以确保在阿里云RDS中看到与本地调试相同的结果。

    2023-06-24 10:05:39
    赞同 展开评论 打赏

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

相关产品

  • 实时计算 Flink版
  • 相关电子书

    更多
    Flink CDC Meetup PPT - 覃立辉 立即下载
    Flink CDC Meetup PPT - 孙家宝 立即下载
    Flink CDC Meetup PPT - 徐榜江 立即下载