gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 15:27:21 25 4
gpt4 key购买 nike

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

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

失败:ValidationFailureSemanticException 分区规范 {partition_date=null} 包含非分区列。

我从这里得到了语法: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');

假设您要更改分区列

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

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

另请参阅此 answer

关于hadoop - 如何重命名配置单元中的所有分区列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42233339/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com