web-dev-qa-db-ja.com

Hive Alterテーブルの変更列名

HiveでcolumnNameの名前を変更しようとしています。 Hiveの列名を変更する方法はありますか?.

tableA(column1、_c1、_c2)to tableA(column1、column2、column3)??

22
user2978621

列名/タイプ/位置/コメントの変更

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;
68
Remus Rusanu

コマンドは、使用するデータベースを定義するために最初に「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
6
user11788
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)
1
minhas23