繁体   English   中英

如何重命名配置单元中的所有分区列

[英]How to rename all partition columns in hive

当我尝试为已分区的一年日期范围重命名现有表中的所有分区列时 - 这就是我得到的。

hive> ALTER TABLE test.usage PARTITION ('date') RENAME TO PARTITION (partition_date);

FAILED: ValidationFailureSemanticException Partition spec {partition_date=null} contains non-partition columns.

我从这里得到了那个语法: 1

鉴于我不是 100% 确定您想要的是重命名分区的值还是实际更改表分区的列。

假设您要重命名分区的值。

Hive 0.13 中存在问题,而 Hive 0.14 中工作正常。 无论如何,这应该有效:

set fs.hdfs.impl.disable.cache=false; 
set fs.file.impl.disable.cache=false; 

现在通过设置此属性运行查询。

> hive> set fs.hdfs.impl.disable.cache=false;  
> hive> set fs.file.impl.disable.cache=false;
> hive> ALTER TABLE test.usage PARTITION (date='oldValue') RENAME TO PARTITION (date='newValue');

假设您要更改分区列

在这种情况下,您需要做的是重新创建表,更改表将被分区的列。

注意:请记住,如果分区内已有数据,则需要重新插入数据。

另请参阅此答案

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM