SQLite嵌入式數據庫系統設計
引 言
本文引用地址:http://www.j9360.com/article/150401.htm 隨著嵌入式系統的廣泛應用及用戶對數據處理和管理需求的不斷提高,各種智能設備與數據庫技術的緊密結合得到重視。這種數據庫不僅具有傳統數據庫的主要功能,還具有嵌入式和支持移動技術兩種特性。可以說,嵌入式數據庫的發展提高了數據信息接入的普遍性,使人們隨時隨地獲取信息的愿望成為可能。
1 嵌入式數據庫系統的體系結構
嵌入式數據庫將數據庫系統與操作系統和具體應用集成在一起,運行在各種智能嵌入式設備上。與傳統的數據庫系統相比,它一般體積較小,有較強的便攜性和易用性,以及較為完備的功能來實現用戶對數據的管理操作。但是,由于嵌入式系統的資源限制,它無法作為一個完整的數據庫來提供大容量的數據管理,而且嵌入式設備可隨處放置,受環境影響較大,數據可靠性較低。在實際應用中,為了彌補嵌入式數據庫存儲容量小、可靠性低的不足,通常在PC機上配置后臺數據庫來實現大容量數據的存儲和管理。嵌入式數據庫作為前端設備,需要一個GUI交互界面來實現嵌入式終端上的人機交互,并通過串口實現和PC機上主數據源之間的數據交換,實現系統服務器端數據的管理,接收嵌入式終端上傳的數據和下載數據到嵌入式終端機等操作。
2 SQLite的體系結構及開發技術
SQLite是D·理查德·希普開發的用一個小型C庫實現的一種強有力的嵌入式關系數據庫管理體制。它提供對SQL92的大多數支持:多表、索引、事務、視圖、觸發和一系列的用戶接口及驅動。
2.1 SQLite的體系結構
SQLite可以分成8個主要子系統,如圖1所示。頂層是標記處理器(tokenizer)和分析器(parser)。高度優化的分析生成器可以快速生成高效率的代碼。底部是基于Knuth經過優化的B樹。這樣可以運行在可調整的頁面緩沖(pagecache)上,有助于將對磁盤的查找減到最少。再往下是頁面高速緩存。它作用在OS的抽象層之上,這樣的安排有助于數據庫的移動。體系結構的核心是虛擬數據庫引擎(VDBE)。VDBE完成與數據操作相關的全部操作并且是客戶和儲存之間進行信息交換的中間單元。它是SQLite的核心。在SQL語句被分析之后,VDBE開始起作用。代碼生成器將分析樹翻譯成一個袖珍程序,隨后這些袖珍程序被組合成用VDBE虛擬機器語言表示的一系列指令。如此往復,VDBE執行每條指令,最終完成SQL語句指定的查詢要求。VDBE的機器語言由圍繞數據庫管理的128個操作碼(op—code)組成。對于打開表、查詢索引、存儲和刪除記錄以及很多其他數據庫操作都有對應的操作碼。VDBE里的每條指令由1個操作碼和3個操作數(operand)組成。一些指令使用全部3個操作數,也有些指令一個也未使用。這完全取決于指令的性質。例如Open指令用于打開一個表的指針,使用了全部3個操作數:第1個操作數(P1)包含指針的ID號,第2個操作數(P2)指出表的根位置(或者表的首頁位置),第3個操作數是表的名字。
2.2 SQLite開發技術
SQLite的API易于使用,只需要3個用來執行SQL和獲得數據的函數。它還是可擴展的,允許程序員自定義函數,然后通過callback()函數集合進去。開放源碼團體已經擴展了眾多的客戶接口、適配器、驅動等,這就使得其他語言使用SQLite也成為可能。
使用C語言API只需要三步。首先,提供文件名和訪問模式,來調用sqlite_open()連接數據庫。然后,執行callback()函數,SQLite通過對每個記錄執行callback()函數獲得從數據庫那里得到的結果。最后,如果想執行一個SQL查詢并獲得一個callback()函數的指針,可以調用sqlite_exec()。另外還可以調用sqlite3_get_table()函數獲得數據表單的內容。
SQLite還提供了存取二進制大對象(BLOB)的方法,同時在線程安全、數據庫管理、API的擴展等方面也都提供了強大方便的技術支持。
3 SQLite在ARM9開發板上的編譯及拷貝
在SQLite官方網www.sqlite.org下載SQLite-3.3.8版本,在終端解壓生成SQLite-3.3.8目錄。進入此目錄,對sqlite/src/sqliteInt.h作一定的修改,以確保btree(B樹)有正確的變量大小。不同體系結構的Linux會有些差別。對于ARM-Linux可找到如下部分:
這樣后面的“typedef INTPTR_TYPE ptr;”就定義為“int”類型,而不是“long long”。
修改configure文件的內容,注釋掉相關代碼,讓系統不去檢查交叉編譯環境,否則會出現錯誤,不能生成Makefile文件。然后新建一個文件夾sqlite-arm-linux來保存將要生成的庫文件,運行以下命令進行配置:
評論