sqlite

資料庫;使用;嵌入式關係資料庫

#alter

英[ˈɔ:ltə(r )]   美[ˈɔltɚ]  

vt.改變;更改;改建(房屋);(人)變老

vi.改變;修改

SQLite Alter命令 語法

作用: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...;

#

SQLite Alter命令 範例

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