Hive表drop删除表后恢复表的分区数据
程序员文章站
2022-07-14 15:11:53
...
如果HDFS配置好回收站的话,drop删除表后可以通过命令恢复表数据,
例如回收站HDFS路径如下:
/user/hdp_teu_dpd/.Trash/Current/
表的HDFS路径如下:
/home/hdp_teu_dpd/warehouse/wbdb.db/dw_smart_merge_idmapping/
当drop table dw_smart_merge_idmapping后,需要恢复数据,可以采用如下命令:
hdfs dfs -mv viewfs://58-cluster/user/hdp_teu_dpd/.Trash/Current/home/hdp_teu_dpd/warehouse/wbdb.db/dw_smart_merge_idmapping/dt=20191020 viewfs://58-cluster/home/hdp_teu_dpd/warehouse/wbdb.db/dw_smart_merge_idmapping/
将每一天的分区数据恢复到hive表的路径上,然后再修复一下hive表元数据即可完成正常的数据select查询
MSCK REPAIR TABLE wbdb.dw_smart_merge_idmapping;
不过需要注意的是这种方法只适合drop删除的表,truncate删除的表数据无法恢复。
上一篇: LeetCode 算法面试汇总 搜索二维矩阵 II
下一篇: Android中杀死所有进程