Hive Alter表更改列名

时间:2014-02-26 12:25:16

标签: hive alter-table alter

我正在尝试重命名Hive中的columnName。有没有办法在Hive中重命名列名。

tableA(column1,_c1,_c2) 至 表A(列1,列2,栏3) ??

4 个答案:

答案 0 :(得分:63)

Change Column Name/Type/Position/Comment

  

ALTER TABLE table_name CHANGE [COLUMN] col_old_name col_new_name column_type [COMMENT col_comment] [FIRST|AFTER column_name]

示例:

CREATE TABLE test_change (a int, b int, c int);

// will change column a's name to a1
ALTER TABLE test_change CHANGE a a1 INT;

答案 1 :(得分:6)

命令仅在首次使用“use”命令定义工作的数据库时才有效。使用DATABASE.TABLE重命名表列会引发错误并且不起作用。版本:HIVE 0.12。

实施例

hive> ALTER TABLE databasename.tablename CHANGE old_column_name new_column_name;

  MismatchedTokenException(49!=90)
        at org.antlr.runtime.BaseRecognizer.recoverFromMismatchedToken(BaseRecognizer.java:617)
        at org.antlr.runtime.BaseRecognizer.match(BaseRecognizer.java:115)
        at org.apache.hadoop.hive.ql.parse.HiveParser.alterStatementSuffixExchangePartition(HiveParser.java:11492)
        ...

hive> use databasename;

hive> ALTER TABLE tablename CHANGE old_column_name new_column_name;

OK

答案 2 :(得分:1)

alter table table_name change old_col_name new_col_name new_col_type;

以下是示例

hive> alter table test change userVisit userVisit2 STRING;      
    OK
    Time taken: 0.26 seconds
    hive> describe test;                                      
    OK
    uservisit2              string                                      
    category                string                                      
    uuid                    string                                      
    Time taken: 0.213 seconds, Fetched: 3 row(s)

答案 3 :(得分:1)

@libjack 在评论中提到了一个非常重要的点。我想对它进行更多说明。首先,我们可以通过 describe <table_name>; 命令检查表的列是什么。 enter image description here

有一个名为 _c1 的双列,当我们将数据从一个表移动到另一个表时,这些列是由配置单元本身创建的。为了解决这些列,我们需要将其写在反引号内

`_c1`

最后,ALTER 命令将是,

ALTER TABLE <table_namr> CHANGE `<system_genarated_column_name>` <new_column_name> <data_type>;