當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀]首先介紹了SQLite嵌入式數(shù)據(jù)庫的結(jié)構(gòu)和特點與選擇必要性及應用到嵌入式系統(tǒng)Wince中的優(yōu)點;其次介紹以ARM9與Wince6.0為平臺,在Visual Studio 2008中開發(fā)的嵌入式數(shù)據(jù)庫。通過研究DataGrid在Windows mobile中自動設置列寬的方法,本設計通過軟件編程解決了基于Wince6.0的ARM9嵌入式設備中存在的問題,并分析通過DataGrid屬性中TableStyles未改變列寬的原因。

隨著科學技術(shù)的發(fā)展,嵌入式系統(tǒng)成為了科技發(fā)展的主要領(lǐng)域, Linus和Wince是比較常見的嵌入式系統(tǒng)。嵌入式開發(fā)過程離不開數(shù)據(jù)庫的應用,對于嵌入式數(shù)據(jù)庫的選擇是必要的。通常,嵌入式系統(tǒng)選擇的數(shù)據(jù)應該盡量小,SQLite[1]在Linux中的應用很廣泛,本設計介紹了SQLite作為一款小巧的嵌入式數(shù)據(jù)庫在Wince[2]中的應用實例。

1 SQLite數(shù)據(jù)庫的介紹與選擇

1.1 SQLite數(shù)據(jù)庫結(jié)構(gòu)

SQLite數(shù)據(jù)庫結(jié)構(gòu)圖如圖1所示。


1.2 SQlite數(shù)據(jù)庫的特點

SQLite是一個開源的嵌入式關(guān)系數(shù)據(jù)庫,結(jié)構(gòu)緊湊,可靠性強[3]。有以下特點:

(1)使用非常簡單。只需要掌握3個核心API函數(shù),大多數(shù)的SQL[4]語句都可以使用。

(2)占用很少的存儲器空間。SQLite完全獨立,數(shù)據(jù)庫引擎和應用程序在同一系統(tǒng)進程中,因此運行速度較高。

(3)支持ACID事務,在系統(tǒng)出現(xiàn)問題或電源斷電時不會出現(xiàn)數(shù)據(jù)丟失現(xiàn)象。

(4)支持多種語言,像C/C++/C#等。

(5)支持多個嵌入式操作系統(tǒng)平臺,如Linux系統(tǒng)、Wince系統(tǒng)等。

2 SQlite的選擇

首先,SQL Server CE是Wince自身的數(shù)據(jù)庫,必須在Wince系統(tǒng)中安裝3個文件才能使用,而SQLite只需要在電腦上安裝SQlite-1.0.65.0[5],把生成的SQlite.Interop.065.DLL移植到Wince系統(tǒng)運行的程序中,并在Visual Studio2008寫程序時添加一個引用即可,操作較簡單。其次SQLite占用很少的存儲器空間(150 KB~250 KB),但是SQL Server CE卻要占用 1 MB~3 MB的空間。最重要的是SQLite具有良好的移植性,可以應用到多個嵌入式系統(tǒng),而SQL Server CE只能在Wince中運行。

3 SQLite的應用硬件及軟件平臺

本文探討中以S3C2440作為處理器ARM9的硬件平臺,以Wince6.0為應用系統(tǒng),支持.NET2.0平臺。在Visual Studio 2008軟件平臺中用 C#中編寫程序,但是在新建項目中選擇智能設備時要選擇.NET2.0平臺。在Visual Studio 2008中用C#編寫程序時,第一次使用時要添加引用System.Data.SQLite,在程序中添加using指令集,這樣可以通過軟件編寫程序?qū)崿F(xiàn)建庫建表的功能。

4 SQLite在Wince中的應用實例

4.1 Wince中顯示數(shù)據(jù)的控件DataGrid及其屬性

DataGrid控件實際上是一個固定的列集合,每一列的行數(shù)都是不確定的,可以看作一個用來顯示數(shù)據(jù)的網(wǎng)格。它的網(wǎng)格是看不見的,只有建立了數(shù)據(jù)表,才能看到其中每一行和每一列的具體內(nèi)容,如果一個單元格的文本太長,就不能在單元格中全部顯示。但是在Wince系統(tǒng)中顯示數(shù)據(jù)的控件只有這一個,所以不能完全顯示數(shù)據(jù)這一問題正是本設計所要解決的。圖2顯示了DataGrid在Wince中的屬性。


4.2 SQLite建數(shù)據(jù)庫的步驟

SQLite建數(shù)據(jù)庫的步驟如下:

(1)通過SQLiteConnection對數(shù)據(jù)庫進行連接[6],通過軟件建數(shù)據(jù)庫,首先要有數(shù)據(jù)源,如:

SQLiteConnection conn=new SQLiteConnection("Data Source=\Program Files\ maindata.db");

對數(shù)據(jù)庫要進行操作需要執(zhí)行的命令,如SQLiteCommand cmd=new SQLiteCommand();

(2)每次使用數(shù)據(jù)庫前需要打開數(shù)據(jù)庫,還需要連接數(shù)據(jù)庫,關(guān)閉數(shù)據(jù)庫;

(3)通過 CREATE TABLE SQL語句進行建表。必須給表注上表名,方便下面操作。如:
{cmd.CommandText="CREATETABLE ServerLert(Numintrger,BedNum varchar(20),ServerItem varchar(50),ServerTime varchar(30),Passwords varchar(30));"

(4)可以通過INSERT INTO語句進行插入數(shù)據(jù)。如:
cmd.CommandText="INSERT INTO ServerLert(Num,BedNum,ServerItem,ServerTime) VALUES(1 ,′2′,′測血糖′,′10-12-10 15:50:00′)";

(5)數(shù)據(jù)庫至此建成,由于插入的時間單元格不能完全顯示,因此需要通過對圖2中標注有灰色背景的TableStyles進行設置[7]。如:
DataGridTableStyle dgts=new DataGridTableStyle();
dgts.MappingName=ds.Tables[0].TableName;
DataGridTextBoxColumn dgtbc=new DataGridTextBoxColumn();
dgtbc.HeaderText=ds.Tables[0].Columns[0].ColumnName;
dgtbc.MappingName=ds.Tables[0].Columns[0].ColumnName;
dgtbc.Width=70;
dgts.GridColumnStyles.Add(dgtbc);

上面是對表中第一列進行的寬度設置主要是對DataGridTableStyle中列的格式進行設置,這就解決了顯示文本過長的問題。第二列設置80,第三列設置了170,在Wince中運行的結(jié)果。如圖3所示。


4.3 Wince通過DataGrid屬性建數(shù)據(jù)庫的分析

DataGrid在應用于基于Wince的Windows mobile[7]智能設備時,主要針對DataGridTableStyle屬性進行設置[8]。根據(jù)應用于Windows mobile的原理對基于Wince的ARM9的嵌入式設備中建數(shù)據(jù)庫還是行不通。對其列的屬性進行操作設置仍然改變不了列的寬度,所以這種路徑行不通。試了很多種方法,最后通過軟件編程進行設置,得到了圖3的結(jié)果。比較DataGridTableStyl進行設置與軟件設置發(fā)現(xiàn),問題在于表的MappingName與列的MappingName設置時,必須對應才能實現(xiàn)修改功能。用DataGridTableStyle設置,如果列的MappingName與數(shù)據(jù)庫中的建表的列不對應,則映射不存在,從而找不到網(wǎng)格去顯示數(shù)據(jù),更無法對數(shù)據(jù)的列寬進行操作。所以通過軟件編程,可以對建在緩存區(qū)域中的每一張表中所有的列進行操作,解決文本過長不能完全顯示的問題。

通過上面的介紹可以看出,SQLite作為開源的嵌入式數(shù)據(jù)庫應用在Wince中的一個優(yōu)點就是建表比較簡單,不像SQL CE數(shù)據(jù)庫[9],在Wince運行中需要先創(chuàng)建表,把所建的數(shù)據(jù)庫放在Wince的系統(tǒng)中,添加數(shù)據(jù)源時再去綁定這個數(shù)據(jù)源。對于在.net2.0平臺建立的數(shù)據(jù)庫[10],添加數(shù)據(jù)源時無法找到路徑,所以這種方法不可行。通過SQLite軟件創(chuàng)建數(shù)據(jù)庫的方法則可以改善上述不足。SQLite作為一款小巧的嵌入式數(shù)據(jù)庫,發(fā)展前景很大,在基于ARM的Wince操作系統(tǒng)有著廣泛應用[11]。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉