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

Flink sql使用系统函数LOCALTIMSTAMP,有时候数据秒的小数点和后面三位小数丢了,有

Flink sql使用系统函数LOCALTIMSTAMP,有时候数据秒的小数点和后面三位小数丢了,有么有大佬知道这是啥问题

展开
收起
游客3oewgrzrf6o5c 2022-08-16 18:09:57 497 0
1 条回答
写回答
取消 提交回答
  • 全栈JAVA领域创作者

    这个问题可能是由于使用LOCALTIMESTAMP函数时没有指定精度造成的。 LOCALTIMESTAMP函数返回的是一个时间戳,可以用于记录系统时间或者存储数据时使用。但是,它返回的时间戳精度不高,可能会导致小数点后位数丢失。 解决这个问题的方法是在调用LOCALTIMESTAMP函数时指定精度,例如使用ROUND或者FLOOR函数来保留小数点后指定位数的位数。 例如,可以使用如下语句来保留6位小数:

    LOCALTIMESTAMP(ROUND(CURRENT_TIMESTAMP AT TIME ZONE 'UTC')) AT TIME ZONE 'UTC' 在上面的语句中,我们使用了ROUND函数来将当前时间戳的精度保留到小数点后6位。这样就可以避免因为精度不够导致的小数点后位数丢失问题。

    2023-06-20 17:41:45
    赞同 展开评论 打赏

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

相关产品

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

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