最近在學習Android,看到了一個新的名詞:SQLite。從字面上大概能夠猜到和資料庫有關,但是具體是什麼意思?Android中的資料庫是什麼樣子?等一連串的問題就出現了,通過上網查,和大家分享一下。
是什麼:
SQLite 資料庫,是一個非常輕量級自包含(lightweight and self-contained)的DBMS,它可移植性好,很容易使用,很小,高效而且可靠。
SQLite 一個非常流行的嵌入式資料庫,它支援 SQL 語言,並且只利用很少的記憶體就有很好的效能。此外它還是開源的,任何人都可以使用它。許多開源項目((Mozilla, PHP, Python)都使用了 SQLite.
SQLite嵌入到使用它的應用程式中,它們共用相同的進程空間,而不是單獨的一個進程。從外部看,它並不像一個RDBMS,但在進程內部,它卻是完整的,自自主資料庫引擎。
嵌入式資料庫的一大好處就是在你的程式內部不需要網路設定,也不需要管理。因為用戶端和伺服器在同一進程空間運行。
SQLite 的資料庫許可權只依賴於檔案系統,沒有使用者帳戶的概念。SQLite 有資料庫級鎖定,沒有網路伺服器。它需要佔用記憶體,但其它開銷很小,適合用於嵌入式裝置,你需要做的僅僅是把它正確的編譯到你的程式。
SQLite 由以下幾個組件組成:SQL 編譯器、核心、後端以及附件。SQLite 通過利用虛擬機器和虛擬資料庫引擎(VDBE),使調試、修改和擴充 SQLite 的核心變得更加方便。
優勢:
SQLite 和其他資料庫最大的不同就是對資料類型的支援,建立一個表時,可以在 CREATE TABLE 語句中指定某列的資料類型,但是你可以把任何資料類型放入任何列中。當某個值插入資料庫時,SQLite 將檢查它的類型。如果該類型與關聯的列不匹配,則 SQLite 會嘗試將該值轉換成該列的類型。如果不能轉換,則該值將作為其本身具有的類型儲存。比如可以把一個字串(String)放入 INTEGER 列。SQLite 稱這為“弱類型”(manifest typing.)。
此外,SQLite 不支援一些標準的 SQL 功能,特別是外鍵約束(FOREIGN KEY constrains),嵌套 transcaction 和 RIGHT OUTER JOIN 和 FULL OUTER JOIN, 還有一些 ALTER TABLE 功能。
綜述:
除了上述功能外,SQLite 是一個完整的 SQL 系統,擁有完整的觸發器,交易等等。
Android 整合了 SQLite 資料庫
Android 在運行時(run-time)整合了 SQLite,所以每個 Android 應用程式都可以使用 SQLite 資料庫。對於熟悉 SQL 的開發人員來時,在 Android 開發中使用 SQLite 相當簡單。但是,由於 JDBC 會消耗太多的系統資源,所以 JDBC 對於手機這種記憶體受限裝置來說並不合適。因此,Android 提供了一些新的 API 來使用 SQLite 資料庫,Android 開發中,程式員需要學使用這些 API。