如何重命名配置单元中的所有分区列
How to rename all partition columns in hive
当我尝试重命名现有 table 中已分区的一年日期范围内的所有分区列时 - 这就是我得到的结果。
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% 确定您想要的是重命名分区的值还是实际更改 table 分区的列。
假设您要重命名分区的值。
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');
假设您要更改分区列
在这种情况下,您需要做的是重新创建 table,更改 table 将被分区的列。
注意:请记住,如果分区中已有数据,则需要重新插入数据。
另请参阅此 answer
当我尝试重命名现有 table 中已分区的一年日期范围内的所有分区列时 - 这就是我得到的结果。
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% 确定您想要的是重命名分区的值还是实际更改 table 分区的列。
假设您要重命名分区的值。
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');
假设您要更改分区列
在这种情况下,您需要做的是重新创建 table,更改 table 将被分区的列。
注意:请记住,如果分区中已有数据,则需要重新插入数据。
另请参阅此 answer