轉於 SQLite 入門教程(二)建立、修改、刪除表html
在關係型數據庫中,數據庫中的表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger 等等,構成了數據庫的架構 Schema。 在 SQL 語句中,專門有一些語句用來定義數據庫架構,這些語句被稱爲「數據庫定義語言」,即 DDL。java
SQLite 數據庫引擎支持下列三種 DDL 語句:sql
其中,CREATE 語句用來建立表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger, DROP語句用來刪除表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger, ALTER TABLE 語句用來改變表的結構。數據庫
今天這一篇只涉及到表的相關內容,視圖、觸發器等到後面再講。ubuntu
SQLite 數據庫中的數據通常由如下幾種經常使用的數據類型組成:架構
SQLite 也能夠接受其餘數據類型。post
首先,建立一個 test.db 數據庫並進入 SQLite 命令行環境,還記得怎麼作嗎?spa
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>
向上面這樣,咱們就在終端中建立了一個 test.db 數據庫,而且經過 .tables 命令查詢數據庫中的表,結果沒有任何返回,由於數據庫原本就是空的嘛。.net
下面咱們建立一個 Student 表,其中包含 Id、Name、Age 等字段.命令行
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>
向上面這樣,一個 Students 表就被創建了,這回再運行 .tables 命令就有響應了,系統告訴咱們數據庫中如今有一個 Students 表, 運行 .schema 命令,返回了咱們建立這個表的 SQL 命令。
SQLite 僅僅支持 ALTER TABLE 語句的一部分功能,咱們能夠用 ALTER TABLE 語句來更改一個表的名字,也可向表中增長一個字段(列),可是咱們不能刪除一個已經存在的字段,或者更改一個已經存在的字段的名稱、數據類型、限定符等等。
下面咱們來演示一下,將前面的 Students 表的名字改成 Teachers
sqlite> sqlite> .tables Students sqlite> ALTER TABLE Students RENAME TO Teachers; sqlite> .tables Teachers sqlite>
原來數據庫中只有一個 Students 表,更名之後再運行 .tables 命令,發現 Students 表已經沒了,如今變成了 Teachers 表。
下面改變 Teachers 表的結構,增長一個 Sex 列
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>
刪除一個表很簡單,只要給出表名便可
下面,咱們將 test.db 中的 Teachers 表刪除
sqlite> sqlite> .tables Teachers sqlite> DROP TABLE Teachers; sqlite> .tables sqlite>
刪除 Teachers 表後再運行 .tables 命令,發現數據庫已經空了。
其實建立一個表遠沒有這麼簡單,表的每一列能夠有不少限定符,好比主列、非空、限制、默認值、惟1、鍵等等,這些內容留到下一篇吧