Impala - 修改表



Impala 中的 ALTER TABLE 语句用于对给定表进行更改。使用此语句,我们可以添加、删除或修改现有表中的列,还可以重命名它。

本章介绍了各种类型的 ALTER 语句,并附有语法和示例。首先假设我们在 Impala 的 my_db 数据库中有一个名为 customers 的表,数据如下所示

ID   NAME     AGE   ADDRESS    SALARY
--- --------- ----- ----------- --------
1   Ramesh    32    Ahmedabad   20000
2   Khilan    25    Delhi       15000
3   Hardik    27    Bhopal      40000
4   Chaitali  25    Mumbai      35000
5   kaushik   23    Kota        30000
6   Komal     22    Mp          32000

并且,如果您获取 my_db 数据库中的表列表,您可以在其中找到 customers 表,如下所示。

[quickstart.cloudera:21000] > show tables;

Query: show tables 
+-----------+ 
| name      | 
+-----------+ 
| customers | 
| employee  | 
| student   | 
| student1  | 
+-----------+

更改表名

语法

ALTER TABLE 重命名现有表的语法如下:

ALTER TABLE [old_db_name.]old_table_name RENAME TO [new_db_name.]new_table_name

示例

以下是使用 alter 语句更改表名的示例。这里我们将表 customers 的名称更改为 users。

[quickstart.cloudera:21000] > ALTER TABLE my_db.customers RENAME TO my_db.users;

执行上述查询后,Impala 会根据需要更改表名,并显示以下消息。

Query: alter TABLE my_db.customers RENAME TO my_db.users

您可以使用 show tables 语句验证当前数据库中的表列表。您可以找到名为 users 的表,而不是 customers。

Query: show tables 
+----------+ 
| name     | 
+----------+ 
| employee | 
| student  | 
| student1 | 
| users    | 
+----------+ 
Fetched 4 row(s) in 0.10s

向表中添加列

语法

ALTER TABLE 向现有表添加列的基本语法如下:

ALTER TABLE name ADD COLUMNS (col_spec[, col_spec ...])

示例

以下查询是一个演示如何向现有表添加列的示例。这里我们在 users 表中添加了两个列 account_no 和 phone_number(两者都是 bigint 数据类型)。

[quickstart.cloudera:21000] > ALTER TABLE users ADD COLUMNS (account_no BIGINT, 
phone_no BIGINT);

执行上述查询后,它将向名为 student 的表添加指定的列,并显示以下消息。

Query: alter TABLE users ADD COLUMNS (account_no BIGINT, phone_no BIGINT)

如果您验证 users 表的架构,您可以在其中找到新添加的列,如下所示。

quickstart.cloudera:21000] > describe users;
 
Query: describe users 
+------------+--------+---------+ 
| name       | type   | comment | 
+------------+--------+---------+ 
| id         | int    |         | 
| name       | string |         | 
| age        | int    |         |
| address    | string |         | 
| salary     | bigint |         | 
| account_no | bigint |         | 
| phone_no   | bigint |         | 
+------------+--------+---------+ 
Fetched 7 row(s) in 0.20s

从表中删除列

语法

ALTER TABLE 在现有表中删除列的基本语法如下:

ALTER TABLE name DROP [COLUMN] column_name

示例

以下查询是删除现有表中列的示例。这里我们删除名为 account_no 的列。

[quickstart.cloudera:21000] > ALTER TABLE users DROP account_no;

执行上述查询后,Impala 会删除名为 account_no 的列,并显示以下消息。

Query: alter TABLE users DROP account_no

如果您验证 users 表的架构,您将找不到名为 account_no 的列,因为它已被删除。

[quickstart.cloudera:21000] > describe users; 

Query: describe users 
+----------+--------+---------+ 
| name     | type   | comment | 
+----------+--------+---------+ 
| id       | int    |         | 
| name     | string |         | 
| age      | int    |         | 
| address  | string |         | 
| salary   | bigint |         | 
| phone_no | bigint |         |
+----------+--------+---------+ 
Fetched 6 row(s) in 0.11s

更改列的名称和类型

语法

ALTER TABLE 更改现有表中列的名称和数据类型的基本语法如下:

ALTER TABLE name CHANGE column_name new_name new_type

示例

以下是使用 alter 语句更改列的名称和数据类型的示例。这里我们将列 phone_no 的名称更改为 email,其数据类型更改为 string。

[quickstart.cloudera:21000] > ALTER TABLE users CHANGE phone_no e_mail string;

执行上述查询后,Impala 会进行指定的更改,并显示以下消息。

Query: alter TABLE users CHANGE phone_no e_mail string

您可以使用 describe 语句验证 users 表的元数据。您可以观察到 Impala 已对指定的列进行了所需的更改。

[quickstart.cloudera:21000] > describe users; 
Query: describe users 
+----------+--------+---------+ 
| name     | type   | comment | 
+----------+--------+---------+ 
| id       | int    |         | 
| name     | string |         | 
| age      | int    |         | 
| address  | string |         | 
| salary   | bigint |         | 
| phone_no | bigint |         |
+----------+--------+---------+ 
Fetched 6 row(s) in 0.11s

使用 Hue 修改表

打开 Impala 查询编辑器,在其中键入 alter 语句,然后单击执行按钮,如下面的屏幕截图所示。

Altering a Table

执行上述查询后,它将把表 customers 的名称更改为 users。同样,我们可以执行所有 alter 查询。

广告