欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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;

Hive表drop删除表后恢复表的分区数据

不过需要注意的是这种方法只适合drop删除的表,truncate删除的表数据无法恢复。