SQLite 的 ALTER TABLE 命令不通過執(zhí)行一個完整的轉(zhuǎn)儲和數(shù)據(jù)的重載來修改已有的表。您可以使用 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...;
實例
假設(shè)我們的 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》孔剩現(xiàn)在蜕劝,讓我們嘗試在 OLD_COMPANY 表中添加一個新的列,如下所示:
sqlite> ALTER TABLE OLD_COMPANY ADD COLUMN SEX char(1);
現(xiàn)在,COMPANY 表已經(jīng)改變岖沛,使用 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 值來填充的。
參考:http://www.w3cschool.cc/sqlite/sqlite-alter-command.html