SQLite - ALTER TABLE 命令



SQLite 的 ALTER TABLE 命令可以修改现有表,无需执行数据的完整转储和重新加载。您可以使用 ALTER TABLE 语句重命名表,并可以使用 ALTER TABLE 语句在现有表中添加列。

除了重命名表和在现有表中添加列之外,SQLite 的 ALTER TABLE 命令不支持其他操作。

语法

以下是用于重命名现有表的ALTER TABLE的基本语法。

ALTER TABLE database_name.table_name RENAME TO new_table_name;

以下是用于在现有表中添加新列的ALTER TABLE的基本语法。

ALTER TABLE database_name.table_name ADD COLUMN column_def...;

示例

考虑具有以下记录的COMPANY表:

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

现在,让我们尝试使用 ALTER TABLE 语句重命名此表:

sqlite> ALTER TABLE COMPANY RENAME TO OLD_COMPANY;

上述 SQLite 语句会将 COMPANY 表重命名为 OLD_COMPANY。现在,让我们尝试在 OLD_COMPANY 表中添加一个新列:

sqlite> ALTER TABLE OLD_COMPANY ADD COLUMN SEX char(1);

COMPANY 表现在已更改,SELECT 语句的输出如下所示。

ID          NAME        AGE         ADDRESS     SALARY      SEX
----------  ----------  ----------  ----------  ----------  ---
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

需要注意的是,新添加的列填充了 NULL 值。

广告