一、數(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ǔ)句:
復(fù)制代碼 代碼如下:
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)境,還記得怎么做嗎?
復(fù)制代碼 代碼如下:
myqiao@ubuntu:~$ sqlite3 test.db
-- Loading resources from /home/myqiao/.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ù),并且通過 .tables 命令查詢數(shù)據(jù)庫(kù)中的表,結(jié)果沒有任何返回,因?yàn)閿?shù)據(jù)庫(kù)本來(lái)就是空的嘛。
下面我們創(chuàng)建一個(gè) Student 表,其中包含 Id、Name、Age 等字段.
復(fù)制代碼 代碼如下:
sqlite>
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);
sqlite>
向上面這樣,一個(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
復(fù)制代碼 代碼如下:
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)沒了,現(xiàn)在變成了 Teachers 表。
下面改變 Teachers 表的結(jié)構(gòu),增加一個(gè) Sex 列
復(fù)制代碼 代碼如下:
sqlite>
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);
sqlite>
五、刪除表 DROP TABLE
刪除一個(gè)表很簡(jiǎn)單,只要給出表名即可
刪除表 - DROP TABLE 表名
下面,我們將 test.db 中的 Teachers 表刪除
復(fù)制代碼 代碼如下:
sqlite>
sqlite> .tables
Teachers
sqlite> DROP TABLE Teachers;
sqlite> .tables
sqlite>
刪除 Teachers 表后再運(yùn)行 .tables 命令,發(fā)現(xiàn)數(shù)據(jù)庫(kù)已經(jīng)空了。
六、后續(xù)內(nèi)容
其實(shí)創(chuàng)建一個(gè)表遠(yuǎn)沒有這么簡(jiǎn)單,表的每一列可以有很多限定符,比如主列、非空、限制、默認(rèn)值、唯一、鍵等等,這些內(nèi)容留到下一篇吧
您可能感興趣的文章:- SQLite3 API 編程手冊(cè)
- SQLite 錯(cuò)誤碼整理
- SQLite學(xué)習(xí)手冊(cè)(SQLite在線備份)
- SQLite3 命令行操作指南
- 為SQLite3提供一個(gè)ANSI到UTF8的互轉(zhuǎn)函數(shù)
- SQLite 內(nèi)存數(shù)據(jù)庫(kù)學(xué)習(xí)手冊(cè)
- SQLite 入門教程四 增刪改查 有講究
- SQLite 入門教程三 好多約束 Constraints
- SQLite 入門教程一 基本控制臺(tái)(終端)命令
- Linux sqlite3 基本命令
- Android使用SQLite數(shù)據(jù)庫(kù)的簡(jiǎn)單實(shí)例
- android中sqlite的按條件查找的小例子
- 基于sqlite特殊字符轉(zhuǎn)義的實(shí)現(xiàn)方法
- 解析SQLite中的常見問題與總結(jié)詳解
- 淺談SQLite時(shí)間函數(shù)的使用說(shuō)明與總結(jié)分析
- 深入SQLite基本操作的總結(jié)詳解
- Android畫圖并保存圖片的具體實(shí)現(xiàn)代碼
- android創(chuàng)建數(shù)據(jù)庫(kù)(SQLite)保存圖片示例