Hive外部表-删除分区

时间:2020-10-05 03:25:30

标签: hadoop hive hive-partitions hiveddl hive-table

面对一个奇怪的问题。 Alter table删除分区的命令对于>或<或> =或<=符号,但不适用于=检查,效果很好。

工作命令:

ALTER TABLE XYZ DROP PARTITION(bizdate>'20231230');

不起作用的命令并抛出错误,指出该分区不存在:

ALTER TABLE XYZ DROP PARTITION(bizdate='20231230');

当我做show partitions时,可以看到'20231230'分区。

注意:bizdatevarchar(10)

1 个答案:

答案 0 :(得分:0)

检查表中的分区列表:

SELECT nmb,nmb2,ROW_NUMBER() OVER (ORDER BY nmb2 asc) AS idx
FROM t
WHERE nmb2 IS NOT NULL

UNION 

SELECT nmb,nmb2,NULL
FROM t
WHERE nmb2 IS null

也许它尝试删除分区。似乎已在HDFS上的某个位置删除了数据,但配置单元表元数据仍然认为这些分区存在

SHOW PARTITIONS <table>;

&重新配对损坏的table

 ALTER TABLE *tableName* drop if exists PARTITION(bizdate="20231230");