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 值填充的。