SQLite 入門教程(二)建立、修改、刪除表

來源:互聯網
上載者:User

一、資料庫定義語言 DDL

在關係型資料庫中,資料庫中的表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger 等等,構成了資料庫的架構 Schema。
在 SQL 陳述式中,專門有一些語句用來定義資料庫結構描述,這些語句被稱為“資料庫定義語言”,即 DDL

SQLite 資料庫引擎支援下列三種 DDL 語句:

  • CREATE
  • ALTER TABLE
  • DROP

其中,CREATE 語句用來建立表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger,
DROP語句用來刪除表 Table、視圖 View、索引 Index、關係 Relationship 和觸發器 Trigger,
ALTER TABLE 語句用來改變表的結構。

今天這一篇只涉及到表的相關內容,視圖、觸發器等到後面再講。

二、SQLite 中的資料類型

SQLite 資料庫中的資料一般由以下幾種常用的資料類型組成:

  • NULL - 空值
  • INTEGER - 有符號整數
  • REAL - 浮點數
  • TEXT - 文本字串
  • BLOB - 位元據,片、聲音等等

SQLite 也可以接受其他資料類型。

三、建立表 CREATE TABLE

首先,建立一個 test.db 資料庫並進入 SQLite 命令列環境,還記得怎麼做嗎?

myqiao@ubuntu:~$ sqlite3 test.db-- Loading resources from /home/myqiao/.sqlitercSQLite version 3.7.4Enter ".help" for instructionsEnter SQL statements terminated with a ";"sqlite> .tablessqlite> 

向上面這樣,我們就在終端中建立了一個 test.db 資料庫,
並且通過 .tables 命令查詢資料庫中的表,結果沒有任何返回,
因為資料庫本來就是空的嘛。

下面我們建立一個 Student 表,其中包含 Id、Name、Age 等欄位.

sqlite> sqlite> CREATE TABLE Students(Id integer,Name text,age integer);sqlite> .tablesStudentssqlite> .schema StudentsCREATE TABLE Students(Id integer,Name text,age integer);sqlite> 

向上面這樣,一個 Students 表就被建立了,這回再運行 .tables 命令就有響應了,
系統告訴我們資料庫中現在有一個 Students 表,
運行 .schema 命令,返回了我們建立這個表的 SQL 命令。

四、修改表 ALTER TABLE

SQLite 僅僅支援 ALTER TABLE 語句的一部分功能,
我們可以用 ALTER TABLE 語句來更改一個表的名字,也可向表中增加一個欄位(列),
但是我們不能刪除一個已經存在的欄位,或者更改一個已經存在的欄位的名稱、資料類型、限定符等等。

  • 改變表名 - ALTER TABLE 舊錶名 RENAME TO 新表名
  • 增加一列 - ALTER TABLE 表名 ADD COLUMN 列名 資料類型 限定符

下面我們來示範一下,將前面的 Students 表的名字改為 Teachers

sqlite> sqlite> .tablesStudentssqlite> ALTER TABLE Students RENAME TO Teachers;sqlite> .tablesTeacherssqlite> 

原來資料庫中只有一個 Students 表,改名以後再運行 .tables 命令,發現 Students 表已經沒了,現在變成了 Teachers 表。

下面改變 Teachers 表的結構,增加一個 Sex 列

sqlite> sqlite> .schema TeachersCREATE TABLE "Teachers"(Id integer,Name text,age integer);sqlite> ALTER TABLE Teachers ADD COLUMN Sex text;sqlite> .schema TeachersCREATE TABLE "Teachers"(Id integer,Name text,age integer, Sex text);sqlite> 

五、刪除表 DROP TABLE

刪除一個表很簡單,只要給出表名即可

  • 刪除表 - DROP TABLE 表名

下面,我們將 test.db 中的 Teachers 表刪除

sqlite> sqlite> .tablesTeacherssqlite> DROP TABLE Teachers;sqlite> .tablessqlite> 

刪除 Teachers 表後再運行 .tables 命令,探索資料庫已經空了。

六、後續內容

其實建立一個表遠沒有這麼簡單,表的每一列可以有很多限定符,比如主列、非空、限制、預設值、唯一、鍵等等,這些內容留到下一篇吧

//===================================================================================================

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.