SQLite數據庫簡介

文檔轉自:http://blog.csdn.net/liuhe688/article/details/6712782感謝博主分享

今天來介紹一下SQLite的相關知識,並結合Java實現對SQLite數據庫的操作。

SQLite是D.Richard Hipp用C語言編寫的開源嵌入式數據庫引擎。它支持大多數的SQL92標準,並且可以在所有主要的操作系統上運行。

SQLite由以下幾個部分組成:SQL編譯器、內核、後端以及附件。SQLite通過利用虛擬機和虛擬數據庫引擎(VDBE),是調試、修改和擴展SQLite的內核變得更加方便。所有SQL語句都被編譯成易讀的、可以在SQLite虛擬機中執行的程序集。SQLite的整體結構圖如下:


值得一提的是,袖珍型的SQLite竟然可以支持高達2TB大小的數據庫,每個數據庫都是以單個文件的形式存在,這些數據都是以B-Tree的數據結構形式存儲在磁盤上。

在事務處理方面,SQLite通過數據庫級上的獨佔性和共享鎖來實現獨立事務處理。這意味着多個進程可以在同一時間從同一數據庫讀取數據,但只有一個可以寫入數據。在某個進程或線程想數據庫執行寫操作之前,必須獲得獨佔鎖。在獲得獨佔鎖之後,其他的讀或寫操作將不會再發生。

SQLite採用動態數據類型,當某個值插入到數據庫時,SQLite將會檢查它的類型,如果該類型與關聯的列不匹配,SQLite則會嘗試將該值轉換成該列的類型,如果不能轉換,則該值將作爲本身的類型存儲,SQLite稱這爲「弱類型」。但有一個特例,如果是INTEGER PRIMARY KEY,則其他類型不會被轉換,會報一個「datatype missmatch」的錯誤。

概括來講,SQLite支持NULL、INTEGER、REAL、TEXT和BLOB數據類型,分別代表空值、整型值、浮點值、字符串文本、二進制對象。

下面,我們就來親自操作一下SQLite數據庫。

在操作之前,朋友們要先下載SQLite數據庫,官方的下載頁面是http://sqlite.org/download.html,我是在Windows下試驗,所以我選擇了Precompiled Binaries For Windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是SQLite數據庫引擎,後者是SQLite數據庫分析器,主要用於分析數據庫的狀態等信息,大家也可以根據自己的情況去下載。下載完成後分別解壓,得到兩個可執行文件,如圖:


這兩個文件可以根據自己的喜好放置在指定的位置,我將其放在D盤根目錄下。下面我們就來一步一步操作SQLite:


創建數據庫:

[sql]  view plain  copy
  1. D:\>sqlite3 test.db  
  2. SQLite version 3.7.7.1 2011-06-28 17:39:05  
  3. Enter ".help" for instructions  
  4. Enter SQL statements terminated with a ";"  
  5. sqlite> .databases  
  6. seq  name             file  
  7.   
  8. ---  ---------------  ----------------------------------------------------------  
  9.   
  10. 0    main             D:\test.db  
  11.   
  12. sqlite>  
我們執行了sqlite3命令,參數就是數據庫的名稱,如果該數據庫已存在,則使用,如果不存在,則新建一個,這裏我們簡單的在當前位置創建了test.db,你也可以在任何存在的並且可寫的目錄下創建自己的數據庫。(如果對於SQLite的命令不太熟悉,可以執行「.help」命令列出所有的命令清單進行查看)。


創建表:

[sql]  view plain  copy
  1. sqlite> CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  
  2. sqlite> .tables  
  3. person  
  4. sqlite> .schema person  
  5. CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  
  6. sqlite>  
在我們創建表之後,可以用「.tables」命令去查看已有的表,用「.schema」命令去查看錶的結構,如果後面沒有表名做參數,則將會輸出所有表的建表語句。


插入數據:

[sql]  view plain  copy
  1. sqlite> INSERT INTO person VALUES (NULL'john', 30);  
  2. sqlite> SELECT * FROM person;  
  3. 1|john|30  


從.sql文件導入數據:

[sql]  view plain  copy
  1. sqlite> .read test.sql  
  2. sqlite> SELECT * FROM person;  
  3. 1|john|30  
  4. 2|david|35  
  5. 3|henry|40  
  6. sqlite>  


分析數據庫使用狀態:

[sql]  view plain  copy
  1. D:\>sqlite3_analyzer test.db  
  2. /** Disk-Space Utilization Report For test.db  
  3.   
  4. Page size in bytes.................... 1024  
  5. Pages in the whole file (measured).... 4  
  6. Pages in the whole file (calculated).. 4  
  7. Pages that store data................. 4          100.0%  
  8. Pages on the freelist (per header).... 0            0.0%  
  9. Pages on the freelist (calculated).... 0            0.0%  
  10. Pages of auto-vacuum overhead......... 0            0.0%  
  11. Number of tables in the database...... 4  
  12. Number of indices..................... 0  
  13. Number of named indices............... 0  
  14. Automatically generated indices....... 0  
  15. Size of the file in bytes............. 4096  
  16. Bytes of user payload stored.......... 39           0.95%  
  17. ...  


備份數據庫:

備份 SQLite 數據庫有兩種方法。如果數據庫正在使用中,則應從命令行界面使用 .dump 命令。這樣可以創建一個包含必要命令和數據的文件,從而重新創建數據庫。.dump 命令也可以用於備份數據庫表。

[sql]  view plain  copy
  1. sqlite> .dump  
  2. PRAGMA foreign_keys=OFF;  
  3. BEGIN TRANSACTION;  
  4. CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  
  5. INSERT INTO "person" VALUES(1,'john',30);  
  6. INSERT INTO "person" VALUES(2,'david',35);  
  7. INSERT INTO "person" VALUES(3,'henry',40);  
  8. DELETE FROM sqlite_sequence;  
  9. INSERT INTO "sqlite_sequence" VALUES('person',3);  
  10. COMMIT;  
  11. sqlite> .output dump.sql  
  12. sqlite> .dump  
  13. sqlite>  
我們可以指定輸出的目標爲一個文件,然後再使用命令時,輸出信息就會寫入指定的文件,如果想恢復爲標準輸出,可以這樣設定:

[sql]  view plain  copy
  1. sqlite> .output stdout  
  2. sqlite> .dump  
  3. PRAGMA foreign_keys=OFF;  
  4. BEGIN TRANSACTION;  
  5. CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  
  6. INSERT INTO "person" VALUES(1,'john',30);  
  7. INSERT INTO "person" VALUES(2,'david',35);  
  8. INSERT INTO "person" VALUES(3,'henry',40);  
  9. DELETE FROM sqlite_sequence;  
  10. INSERT INTO "sqlite_sequence" VALUES('person',3);  
  11. COMMIT;  
  12. sqlite>  

如果數據庫沒有處於使用狀態,則可以直接將數據庫文件複製到安全位置。

最後,我們可以使用「.quit」或「.exit」退出SQLite。


管理工具:

現在網絡上的SQLite管理工具很多,我向大家推薦一款好用的工具:SQLite Expert。



在Java中使用SQLite:

我們要想在Java中使用SQLite,需要下載SQLite相關驅動,推薦大家到http://www.xerial.org/trac/Xerial/wiki/SQLiteJDBC頁面去下載最新的驅動包,現在最新版本是sqlite-jdbc-3.7.2.jar,體積有點大,因爲它包含了Linux、Mac、Windows的本地類庫,如圖:


下載了驅動之後,我們新建一個項目,名爲sqlite:


在上圖中,我們引入sqlite驅動包到類路徑下,然後建立一個db的文件夾,用於放置數據庫文件。最後我們看一下Test.java代碼:

[java]  view plain  copy
  1. package com.scott.sqlite;  
  2. import java.sql.Connection;  
  3. import java.sql.DriverManager;  
  4. import java.sql.ResultSet;  
  5. import java.sql.Statement;  
  6.   
  7. public class Test {  
  8.     public static void main(String[] args) throws Exception {  
  9.         Class.forName("org.sqlite.JDBC");  
  10.         Connection conn = DriverManager.getConnection("jdbc:sqlite:db/test.db");  
  11.         Statement stmt = conn.createStatement();  
  12.   
  13.         stmt.executeUpdate("DROP TABLE IF EXISTS person");  
  14.         stmt.executeUpdate("CREATE TABLE person(id INTEGER, name STRING)");  
  15.         stmt.executeUpdate("INSERT INTO person VALUES(1, 'john')");  
  16.         stmt.executeUpdate("INSERT INTO person VALUES(2, 'david')");  
  17.         stmt.executeUpdate("INSERT INTO person VALUES(3, 'henry')");  
  18.         ResultSet rs = stmt.executeQuery("SELECT * FROM person");  
  19.         while (rs.next()) {  
  20.             System.out.println("id=>" + rs.getInt("id") + ", name=>" + rs.getString("name"));  
  21.         }  
  22.         stmt.close();  
  23.         conn.close();  
  24.     }  
  25. }  
執行Test.java文件,結果如下:


這個時候,在我們的db目錄下,就生成了一個test.db的文件:



SQLite使用須知:

目前沒有可用於 SQLite 的網絡服務器。從應用程序運行位於其他計算機上的 SQLite 的惟一方法是從網絡共享運行。這樣會導致一些問題,像 UNIX® 和 Windows® 網絡共享都存在文件鎖定問題。還有由於與訪問網絡共享相關的延遲而帶來的性能下降問題。

SQLite 只提供數據庫級的鎖定。

SQLite 沒有用戶帳戶概念,而是根據文件系統確定所有數據庫的權限。


結束語:

由於資源佔用少、性能良好和零管理成本,嵌入式數據庫有了它的用武之地,像Android、iPhone都有內置的SQLite數據庫供開發人員使用,它的易用性可以加快應用程序的開發,並使得複雜的數據存儲變得輕鬆了許多。