J'essaye de renommer un columnName dans Hive. Est-il possible de renommer le nom de la colonne dans Hive?.
tableA (colonne1, _c1, _c2) à tableA (colonne1, colonne2, colonne3) ??
Changer le nom de la colonne/le type/la position/le commentaire :
ALTER TABLE table_name CHANGE [COLUMN] col_old_name col_new_name column_type [COMMENT col_comment] [FIRST|AFTER column_name]
Exemple:
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;
La commande ne fonctionne que si "use" -command a d'abord été utilisé pour définir la base de données. La syntaxe de renommage de colonne de table à l'aide de DATABASE.TABLE génère une erreur et ne fonctionne pas. Version: Ruche 0.12.
EXEMPLE:
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;
Voici l'exemple
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)