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

repair 之后Hive 上就可以查到数据了,还知道是什么原因导致的?

repair 之后Hive 上就可以查到数据了,还知道是什么原因导致的?

展开
收起
十一0204 2023-04-03 16:59:51 225 0
2 条回答
写回答
取消 提交回答
  • 意中人就是我呀!

    不清楚了, insert 应该不会出现这个问题才对。我这边没有flink 写hive的场景。具体不太清楚。此回答整理自钉群“Flink CDC 社区”

    2023-04-05 09:11:05
    赞同 展开评论 打赏
  • 存在即是合理

    在 Hive 中,如果使用了分区表(Partitioned Table),那么在加载新的数据后,可能需要使用 MSCK REPAIR TABLE 命令来进行元数据的修复,以确保分区信息和数据文件的匹配关系正确。

    具体来说,MSCK REPAIR TABLE 命令会扫描指定表的所有分区目录,将其中的数据文件与表的元数据信息进行匹配,并将未在元数据中注册的分区添加到表的元数据中,以便查询时能够正确地读取到数据。如果不执行 MSCK REPAIR TABLE 命令,查询分区表时可能会出现部分数据无法查询的情况。

    需要注意的是,MSCK REPAIR TABLE 命令的执行需要一定的时间,特别是对于数据量较大的表来说,可能会比较耗时。因此,建议在数据量较小的时候进行元数据的修复,以便更快地将新数据纳入查询范围。

    2023-04-03 17:08:41
    赞同 展开评论 打赏

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

相关电子书

更多
Hive Bucketing in Apache Spark 立即下载
spark替代HIVE实现ETL作业 立即下载
2019大数据技术公开课第五季—Hive迁移到MaxCompute最佳实践 立即下载