<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 48,comments - 156,trackbacks - 0

    一、數據庫定義語言 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/.sqliterc
    SQLite version 3.7.4
    Enter ".help" for instructions
    Enter SQL statements terminated with a ";"
    sqlite> .tables
    sqlite> 
    

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

    下面我們創建一個 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 命令。

    四、修改表 ALTER TABLE

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

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

    下面我們來演示一下,將前面的 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> 
    

    五、刪除表 DROP TABLE

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

    • 刪除表 - DROP TABLE 表名

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

    sqlite> 
    sqlite> .tables
    Teachers
    sqlite> DROP TABLE Teachers;
    sqlite> .tables
    sqlite> 
    

    刪除 Teachers 表后再運行 .tables 命令,發現數據庫已經空了。

    六、后續內容

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


    //===================================================================================================
    posted on 2011-07-12 00:33 左洸 閱讀(4180) 評論(0)  編輯  收藏 所屬分類: SQLite
    主站蜘蛛池模板: 一本到卡二卡三卡免费高| 亚洲AV无码之国产精品| 美女无遮挡拍拍拍免费视频| www国产亚洲精品久久久| 精品亚洲国产成人av| 国产精品久免费的黄网站| 亚洲一卡一卡二新区无人区 | 中文字幕日本人妻久久久免费| 亚洲日本中文字幕一区二区三区| 理论片在线观看免费| 亚洲视频在线一区二区| 精品国产福利尤物免费| 久久精品国产精品亚洲蜜月| 毛片在线全部免费观看| 亚洲色图.com| 国产免费av片在线看| 久久亚洲欧美国产精品| 亚洲精品岛国片在线观看| 你懂的在线免费观看| 亚洲一区二区三区日本久久九| 麻豆视频免费播放| 亚洲妇女无套内射精| 亚洲色偷拍区另类无码专区| 老汉精品免费AV在线播放| 亚洲久悠悠色悠在线播放| 国产无遮挡吃胸膜奶免费看视频| 无套内射无矿码免费看黄| 国产亚洲精品岁国产微拍精品| 99久久免费观看| 亚洲AV无码AV吞精久久| 国产亚洲精品免费视频播放| 免费看又黄又无码的网站| 亚洲美国产亚洲AV| 在线观看亚洲精品国产| 16女性下面无遮挡免费| 丰满亚洲大尺度无码无码专线| 亚洲愉拍99热成人精品热久久| 在线永久免费的视频草莓| 边摸边吃奶边做爽免费视频网站 | 一区二区三区免费电影| 久久亚洲sm情趣捆绑调教|