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