Изменение таблицы изменения объема ячейки Название столбца

Я пытаюсь переименовать columnName в Hive. Есть ли способ переименовать имя столбца в Hive.

tableA (column1, _c1, _c2) в TableA (столбец1, столбец2, Столбец3) ??

Ответ 2

Команда работает только в том случае, если команда "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

Ответ 3

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)