Hive外部表-删除分区

问题描述

面对一个奇怪的问题。 Alter table删除分区的命令对于>或 =或

工作命令:

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

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

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

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

注意:bizdatevarchar(10)

解决方法

检查表中的分区列表:

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

UNION 

SELECT nmb,NULL
FROM t
WHERE nmb2 IS null

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

SHOW PARTITIONS <table>;

&重新配对损坏的table

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...