SQLite 創(chuàng)建、修改、刪除表
SQLite 創(chuàng)建、修改、刪除表
一、數(shù)據(jù)庫(kù)定義語(yǔ)言?DDL
在關(guān)系型數(shù)據(jù)庫(kù)中,數(shù)據(jù)庫(kù)中的表?Table、視圖?View、索引?Index、
關(guān)系?Relationship?和觸發(fā)器?Trigger?等等,構(gòu)成了數(shù)據(jù)庫(kù)的架構(gòu)?
Schema。?在?SQL?語(yǔ)句中,專門有一些語(yǔ)句用來(lái)定義數(shù)據(jù)庫(kù)架構(gòu),這
些語(yǔ)句被稱為“數(shù)據(jù)庫(kù)定義語(yǔ)言”,即?DDL。
SQLite?數(shù)據(jù)庫(kù)引擎支持下列三種?DDL?語(yǔ)句:
????CREATE
????ALTER?TABLE
????DROP
其中,CREATE?語(yǔ)句用來(lái)創(chuàng)建表?Table、視圖?View、索引?Index、關(guān)
系?Relationship?和觸發(fā)器?Trigger,?DROP語(yǔ)句用來(lái)刪除表?Table、
視圖?View、索引?Index、關(guān)系?Relationship?和觸發(fā)器?Trigger,?
ALTER?TABLE?語(yǔ)句用來(lái)改變表的結(jié)構(gòu)。
今天這一篇只涉及到表的相關(guān)內(nèi)容,視圖、觸發(fā)器等到后面再講。
二、SQLite?中的數(shù)據(jù)類型
SQLite?數(shù)據(jù)庫(kù)中的數(shù)據(jù)一般由以下幾種常用的數(shù)據(jù)類型組成:
????NULL?-?空值
????INTEGER?-?有符號(hào)整數(shù)
????REAL?-?浮點(diǎn)數(shù)
????TEXT?-?文本字符串
????BLOB?-?二進(jìn)制數(shù)據(jù),如圖片、聲音等等
SQLite?也可以接受其他數(shù)據(jù)類型。
三、創(chuàng)建表?CREATE?TABLE
首先,創(chuàng)建一個(gè)?test.db?數(shù)據(jù)庫(kù)并進(jìn)入?SQLite?命令行環(huán)境,還記得
怎么做嗎?
[xiazhujie@localhost]:~$?sqlite3?test.db
--?Loading?resources?from?/home/xiazhujie
/.sqliterc
SQLite?version?3.7.4
Enter?".help"?for?instructions
Enter?SQL?statements?terminated?with?a?";"
sqlite>?.tables
sqlite>
向上面這樣,我們就在終端中創(chuàng)建了一個(gè)?test.db?數(shù)據(jù)庫(kù),并且通過(guò)?
.tables?命令查詢數(shù)據(jù)庫(kù)中的表,結(jié)果沒(méi)有任何返回,因?yàn)閿?shù)據(jù)庫(kù)本
來(lái)就是空的嘛。
下面我們創(chuàng)建一個(gè)?Student?表,其中包含?Id、Name、Age?等字段.
sqlite>?CREATE?TABLE?Students(Id?integer,Name?text,age?
integer);
sqlite>?.tables
Students
sqlite>?.schema?Students
CREATE?TABLE?Students(Id?integer,Name?text,age?integer);
向上面這樣,一個(gè)?Students?表就被建立了,這回再運(yùn)行?.tables?命
令就有響應(yīng)了,系統(tǒng)告訴我們數(shù)據(jù)庫(kù)中現(xiàn)在有一個(gè)?Students?表,?運(yùn)
行?.schema?命令,返回了我們創(chuàng)建這個(gè)表的?SQL?命令。
四、修改表?ALTER?TABLE
SQLite?僅僅支持?ALTER?TABLE?語(yǔ)句的一部分功能,我們可以用?
ALTER?TABLE?語(yǔ)句來(lái)更改一個(gè)表的名字,也可向表中增加一個(gè)字段(
列),但是我們不能刪除一個(gè)已經(jīng)存在的字段,或者更改一個(gè)已經(jīng)存
在的字段的名稱、數(shù)據(jù)類型、限定符等等。
????改變表名?-?ALTER?TABLE?舊表名?RENAME?TO?新表名
????增加一列?-?ALTER?TABLE?表名?ADD?COLUMN?列名?數(shù)據(jù)類型?限定
符
下面我們來(lái)演示一下,將前面的?Students?表的名字改為?Teachers
sqlite>
sqlite>?.tables
Students
sqlite>?ALTER?TABLE?Students?RENAME?TO?Teachers;
sqlite>?.tables
Teachers
sqlite>
原來(lái)數(shù)據(jù)庫(kù)中只有一個(gè)?Students?表,改名以后再運(yùn)行?.tables?命令
,發(fā)現(xiàn)?Students?表已經(jīng)沒(méi)了,現(xiàn)在變成了?Teachers?表。
下面改變?Teachers?表的結(jié)構(gòu),增加一個(gè)?Sex?列
sqlite>?.schema?Teachers
CREATE?TABLE?"Teachers"(Id?integer,Name?text,age?integer);
sqlite>?ALTER?TABLE?Teachers?ADD?COLUMN?Sex?text;
sqlite>?.schema?Teachers
CREATE?TABLE?"Teachers"(Id?integer,Name?text,age?integer,?Sex?
text);
五、刪除表?DROP?TABLE
刪除一個(gè)表很簡(jiǎn)單,只要給出表名即可
????刪除表?-?DROP?TABLE?表名
下面,我們將?test.db?中的?Teachers?表刪除
sqlite>?.tables
Teachers
sqlite>?DROP?TABLE?Teachers;
sqlite>?.tables
刪除?Teachers?表后再運(yùn)行?.tables?命令,發(fā)現(xiàn)數(shù)據(jù)庫(kù)已經(jīng)空了。