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 值。