SQLite ALTER TABLE命令可修改現(xiàn)有表,而無需執(zhí)行數(shù)據(jù)的完整轉(zhuǎn)儲和重新加載。 您可以使用ALTER TABLE語句重命名表,并可以使用ALTER TABLE語句在現(xiàn)有表中添加其他列。
除了重命名表和在現(xiàn)有表中添加列之外,SQLite中的ALTER TABLE命令不支持其他操作。
以下是ALTER TABLE重命名現(xiàn)有表的基本語法。
ALTER TABLE database_name.table_name RENAME TO new_table_name;
以下是ALTER TABLE在現(xiàn)有表中添加新列的基本語法。
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
現(xiàn)在,讓我們嘗試使用ALTER TABLE語句重命名該表,如下所示:
sqlite> ALTER TABLE COMPANY RENAME TO OLD_COMPANY;
上面的SQLite語句會將COMPANY表重命名為OLD_COMPANY?,F(xiàn)在,讓我們嘗試在OLD_COMPANY表中添加新列,如下所示:
sqlite> ALTER TABLE OLD_COMPANY ADD COLUMN SEX char(1);
COMPANY表現(xiàn)在已更改,以下將是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
應(yīng)當(dāng)注意,新添加的列填充有NULL值。