Я пытаюсь переименовать columnName в Hive. Есть ли способ переименовать имя столбца в Hive.
tableA (column1, _c1, _c2) в TableA (столбец1, столбец2, Столбец3) ??
Я пытаюсь переименовать columnName в Hive. Есть ли способ переименовать имя столбца в Hive.
tableA (column1, _c1, _c2) в TableA (столбец1, столбец2, Столбец3) ??
Изменить имя столбца/тип/положение/комментарий:
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 name to a1
ALTER TABLE test_change CHANGE a a1 INT;
Команда работает только в том случае, если команда "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
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)