0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

探究SQLite在嵌入式系統(tǒng)Wince中的應用

電子工程師 ? 來源:微型機與應用蔣晶,郝繼 ? 作者:微型機與應用蔣晶 ? 2021-03-31 10:39 ? 次閱讀

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

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

1.1 SQLite數(shù)據(jù)庫結構

SQLite數(shù)據(jù)庫結構圖如圖1所示。

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

SQLite是一個開源的嵌入式關系數(shù)據(jù)庫,結構緊湊,可靠性強。有以下特點:

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

(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,把生成的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指令集,這樣可以通過軟件編寫程序實現(xiàn)建庫建表的功能。

4 SQLite在Wince中的應用實例

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

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

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

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

(1)通過SQLiteConnection對數(shù)據(jù)庫進行連接,通過軟件建數(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ù)庫,關閉數(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中運行的結果。如圖3所示。

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

DataGrid在應用于基于Wince的Windows mobile智能設備時,主要針對DataGridTableStyle屬性進行設置。根據(jù)應用于Windows mobile的原理對基于Wince的ARM9的嵌入式設備中建數(shù)據(jù)庫還是行不通。對其列的屬性進行操作設置仍然改變不了列的寬度,所以這種路徑行不通。試了很多種方法,最后通過軟件編程進行設置,得到了圖3的結果。比較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ù)庫,在Wince運行中需要先創(chuàng)建表,把所建的數(shù)據(jù)庫放在Wince的系統(tǒng)中,添加數(shù)據(jù)源時再去綁定這個數(shù)據(jù)源。對于在.net2.0平臺建立的數(shù)據(jù)庫,添加數(shù)據(jù)源時無法找到路徑,所以這種方法不可行。通過SQLite軟件創(chuàng)建數(shù)據(jù)庫的方法則可以改善上述不足。SQLite作為一款小巧的嵌入式數(shù)據(jù)庫,發(fā)展前景很大,在基于ARM的Wince操作系統(tǒng)有著廣泛應用。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5059

    文章

    18974

    瀏覽量

    302065
  • API
    API
    +關注

    關注

    2

    文章

    1472

    瀏覽量

    61750
  • 數(shù)據(jù)庫

    關注

    7

    文章

    3752

    瀏覽量

    64233
  • ACI
    ACI
    +關注

    關注

    0

    文章

    6

    瀏覽量

    9944
收藏 人收藏

    評論

    相關推薦

    嵌入式系統(tǒng)與物聯(lián)網(wǎng)的結合

    隨著科技的飛速發(fā)展,嵌入式系統(tǒng)和物聯(lián)網(wǎng)(IoT)已經(jīng)成為現(xiàn)代技術領域的重要組成部分。嵌入式系統(tǒng)是指嵌入到設備或
    的頭像 發(fā)表于 11-06 10:23 ?143次閱讀

    什么是嵌入式?一文讀懂嵌入式主板

    現(xiàn)代科技浪潮嵌入式技術已成為支撐各種智能設備和系統(tǒng)運行的核心力量。那么,究竟什么是嵌入式?嵌入式
    的頭像 發(fā)表于 10-16 10:14 ?388次閱讀

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統(tǒng)的核心組件,是一種用于控制和數(shù)據(jù)處理的計算機硬件,其設計旨在嵌入特定設備執(zhí)行專門任務。
    的頭像 發(fā)表于 09-30 10:05 ?315次閱讀

    嵌入式系統(tǒng)的未來趨勢有哪些?

    會更加模塊化和集成化,允許更容易的硬件和軟件的切換和升級。這會提高系統(tǒng)的可維護性和可擴展性,會使得系統(tǒng)能夠適應不斷變化的應用需求。 5. 生態(tài)可持續(xù)性與環(huán)保材料
    發(fā)表于 09-12 15:42

    嵌入式系統(tǒng)的實時操作系統(tǒng)

    嵌入式RTOS是嵌入式應用程序運行、相互交互和與外界通信的底層軟件機制。本節(jié),您將了解嵌入式軟件開發(fā)人員使用哪些流行RTOS以及它們運行
    的頭像 發(fā)表于 08-20 11:28 ?421次閱讀

    機器視覺嵌入式的應用

    機器視覺嵌入式系統(tǒng)的應用是一個廣泛而深入的話題,涉及到許多不同的領域和技術。 機器視覺嵌入式
    的頭像 發(fā)表于 07-16 10:30 ?424次閱讀

    嵌入式系統(tǒng)怎么學?

    、C++或者Python。這些語言嵌入式系統(tǒng)開發(fā)中都被廣泛應用。 3、微處理器/微控制器架構:學習常見的微處理器和微控制器架構,如ARM、AVR、PIC等,了解其特性和應用場景。 4、
    發(fā)表于 07-02 10:10

    入門嵌入式系統(tǒng)這些知識你知道嗎?

    嵌入式系統(tǒng)是一種專用的計算機系統(tǒng),作為裝置或設備的一部分。通常,嵌入式系統(tǒng)是一個控制程序存儲R
    發(fā)表于 05-03 09:54 ?505次閱讀

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術集成到嵌入式系統(tǒng)的一種解決方案。嵌入式系統(tǒng)是一種為特定應用而設
    的頭像 發(fā)表于 03-15 14:29 ?1168次閱讀

    fpga是嵌入式

    FPGA(現(xiàn)場可編程門陣列)不是嵌入式系統(tǒng),但FPGA嵌入式系統(tǒng)中有著重要的應用。
    的頭像 發(fā)表于 03-14 17:19 ?2088次閱讀

    嵌入式系統(tǒng)發(fā)展前景?

    、舒適的生活體驗。 工業(yè)自動化和智能制造是嵌入式系統(tǒng)的重要應用領域。未來,隨著工業(yè)4.0的推進,嵌入式系統(tǒng)將更為廣泛地應用于生產(chǎn)設備、機器人、自動化流水線等,從而提高生產(chǎn)效率和質量。
    發(fā)表于 02-22 14:09

    嵌入式系統(tǒng)的應用實例

    嵌入式系統(tǒng)的三個基本要素是嵌入性、專用性與計算機系統(tǒng)。
    的頭像 發(fā)表于 01-22 09:57 ?988次閱讀

    嵌入式系統(tǒng)堆棧監(jiān)控的作用

    微控制器或微處理器,堆棧是內存的一個保留區(qū)域,用于存儲臨時數(shù)據(jù)和函數(shù)調用信息,管理函數(shù)的執(zhí)行,跟蹤返回地址、局部變量和函數(shù)參數(shù)。堆棧監(jiān)控是嵌入式系統(tǒng)運行
    的頭像 發(fā)表于 01-05 11:13 ?454次閱讀

    什么是嵌入式系統(tǒng)?嵌入式系統(tǒng)的具體應用

    嵌入式,一般是指嵌入式系統(tǒng)。用于控制、監(jiān)視或者輔助操作機器和設備的裝置。
    的頭像 發(fā)表于 12-20 13:33 ?2342次閱讀

    嵌入式系統(tǒng)原理與設計

    電子發(fā)燒友網(wǎng)站提供《嵌入式系統(tǒng)原理與設計.zip》資料免費下載
    發(fā)表于 11-17 14:10 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>原理與設計