天天看點

Android SQLite (一) 資料庫簡介

大家好,今天來介紹一下SQLite的相關知識,并結合Java實作對SQLite資料庫的操作。

SQLite是D.Richard Hipp用C語言編寫的開源嵌入式資料庫引擎。它支援大多數的SQL92标準,并且可以在所有主要的作業系統上運作。

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

Android SQLite (一) 資料庫簡介

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

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

SQLite采用動态資料類型,當某個值插入到資料庫時,SQLite将會檢查它的類型,如果該類型與關聯的列不比對,SQLite則會嘗試将該值 轉換成該列的類型,如果不能轉換,則該值将作為本身的類型存儲,SQLite稱這為“弱類型”。但有一個特例,如果是INTEGER PRIMARY KEY,則其他類型不會被轉換,會報一個“datatype missmatch”的錯誤。

概括來講,SQLite支援NULL、INTEGER、REAL、TEXT和BLOB資料類型,分别代表空值、整型值、浮點值、字元串文本、二進制對象。

下面,我們就來親自操作一下SQLite資料庫。

Android SQLite (一) 資料庫簡介

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

建立資料庫:

D:\>sqlite3 test.db  

SQLite version 3.7.7.1 2011-06-28 17:39:05  

Enter ".help" for instructions  

Enter SQL statements terminated with a ";"  

sqlite> .databases  

seq  name             file  

---  ---------------  ----------------------------------------------------------  

0    main             D:\test.db  

sqlite>  

我 們執行了sqlite3指令,參數就是資料庫的名稱,如果該資料庫已存在,則使用,如果不存在,則建立一個,這裡我們簡單的在目前位置建立了 test.db,你也可以在任何存在的并且可寫的目錄下建立自己的資料庫。(如果對于SQLite的指令不太熟悉,可以執行“.help”指令列出所有的 指令清單進行檢視)。

建立表:

sqlite> CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  

sqlite> .tables  

person  

sqlite> .schema person  

CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);  

在我們建立表之後,可以用“.tables”指令去檢視已有的表,用“.schema”指令去檢視表的結構,如果後面沒有表名做參數,則将會輸出所有表的建表語句。

插入資料:

sqlite> INSERT INTO person VALUES (NULL, 'john', 30);  

sqlite> SELECT * FROM person;  

1|john|30  

從.sql檔案導入資料:

sqlite> .read test.sql  

2|david|35  

3|henry|40  

分析資料庫使用狀态:

D:\>sqlite3_analyzer test.db  

/** Disk-Space Utilization Report For test.db  

Page size in bytes.................... 1024  

Pages in the whole file (measured).... 4  

Pages in the whole file (calculated).. 4  

Pages that store data................. 4          100.0%  

Pages on the freelist (per header).... 0            0.0%  

Pages on the freelist (calculated).... 0            0.0%  

Pages of auto-vacuum overhead......... 0            0.0%  

Number of tables in the database...... 4  

Number of indices..................... 0  

Number of named indices............... 0  

Automatically generated indices....... 0  

Size of the file in bytes............. 4096  

Bytes of user payload stored.......... 39           0.95%  

...  

備份資料庫:

備份 SQLite 資料庫有兩種方法。如果資料庫正在使用中,則應從指令行界面使用 .dump 指令。這樣可以建立一個包含必要指令和資料的檔案,進而重新建立資料庫。.dump 指令也可以用于備份資料庫表。

sqlite> .dump  

PRAGMA foreign_keys=OFF;  

BEGIN TRANSACTION;  

INSERT INTO "person" VALUES(1,'john',30);  

INSERT INTO "person" VALUES(2,'david',35);  

INSERT INTO "person" VALUES(3,'henry',40);  

DELETE FROM sqlite_sequence;  

INSERT INTO "sqlite_sequence" VALUES('person',3);  

COMMIT;  

sqlite> .output dump.sql  

我們可以指定輸出的目标為一個檔案,然後再使用指令時,輸出資訊就會寫入指定的檔案,如果想恢複為标準輸出,可以這樣設定:

sqlite> .output stdout  

如果資料庫沒有處于使用狀态,則可以直接将資料庫檔案複制到安全位置。

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

管理工具:

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

Android SQLite (一) 資料庫簡介

在Java中使用SQLite:

下載下傳了驅動之後,我們建立一個項目,名為sqlite:

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

package com.scott.sqlite;  

import java.sql.Connection;  

import java.sql.DriverManager;  

import java.sql.ResultSet;  

import java.sql.Statement;  

public class Test {  

    public static void main(String[] args) throws Exception {  

        Class.forName("org.sqlite.JDBC");  

        Connection conn = DriverManager.getConnection("jdbc:sqlite:db/test.db");  

        Statement stmt = conn.createStatement();  

        stmt.executeUpdate("DROP TABLE IF EXISTS person");  

        stmt.executeUpdate("CREATE TABLE person(id INTEGER, name STRING)");  

        stmt.executeUpdate("INSERT INTO person VALUES(1, 'john')");  

        stmt.executeUpdate("INSERT INTO person VALUES(2, 'david')");  

        stmt.executeUpdate("INSERT INTO person VALUES(3, 'henry')");  

        ResultSet rs = stmt.executeQuery("SELECT * FROM person");  

        while (rs.next()) {  

            System.out.println("id=>" + rs.getInt("id") + ", name=>" + rs.getString("name"));  

        }  

        stmt.close();  

        conn.close();  

    }  

}  

執行Test.java檔案,結果如下:

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

SQLite使用須知:

目前沒有可用于 SQLite 的網絡伺服器。從應用程式運作位于其他計算機上的 SQLite 的惟一方法是從網絡共享運作。這樣會導緻一些問題,像 UNIX® 和 Windows® 網絡共享都存在檔案鎖定問題。還有由于與通路網絡共享相關的延遲而帶來的性能下降問題。

SQLite 隻提供資料庫級的鎖定。

SQLite 沒有使用者帳戶概念,而是根據檔案系統确定所有資料庫的權限。

結束語:

由于資源占用少、性能良好和零管理成本,嵌入式資料庫有了它的用武之地,像Android、iPhone都有内置的SQLite資料庫供開發人員使用,它的易用性可以加快應用程式的開發,并使得複雜的資料存儲變得輕松了許多

    本文轉自 一點點征服   部落格園部落格,原文連結:http://www.cnblogs.com/ldq2016/p/5237684.html,如需轉載請自行聯系原作者