久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > WinCE中基于XML的數據同步

WinCE中基于XML的數據同步

作者: 時間:2016-10-08 來源:網絡 收藏

當前主流的嵌入式系統的操作系統(OS)包括WinCE、Palm等等,其中以Palm的歷史最為長久,但是以WinCE的普及推廣速度最快,操作最為靈活,應用最為廣泛,因此當前時期,大多數的用戶選擇WinCE作為當前嵌入式系統的操作系統。

2.2.1.WinCE操作系統

WinCE操作系統是嵌入式操作系統中的一種,為微軟所研制開發,包含WinCE、WinCE.NET、Windows XP Embedded等一系列的Mobile Windows家族。正迅速地為人們所接受。

2.2.2.Compact .Net FrameWork

隨著.NET開發平臺2003版的推出,微軟包容了嵌入式系統的開發,使得嵌入式系統的開發更為簡便更為容易。

2.3.XML文件傳輸

由于XML是一個文本類型的文件,因此具備跨平臺的能力,可以為UNIX、LINUX等非Windows平臺所接受,由于是文本類型的文件,因此傳輸方式可以多種多樣。比如使用存儲器進行傳輸,存儲器包括存儲卡、磁盤、磁帶等等存儲載體;也可以通過網絡下載復制的功能,比如通過有線或無線局域網,或者GPRS、Moden等等網絡載體;還可以通過紅外端口的發送接收文件的方式進行傳輸。

3.實現方法

由于是WinCE,因此可以使用Visual Studio .Net 2003版進行編程,利用Visual Studio .NET 2003版中帶的Compact .Net FrameWork,使所編制的程序可以運行在WinCE的嵌入式系統中。

針對微軟的.NET計劃,相信不久的將來,Compact .Net FrameWork也可以運行到Palm等其它嵌入式系統中。

3.1.PC端XML數據導出

假設我們已經有了數據庫連接SQLconn,strSQL是待執行的SQL語句,則我們的PC端服務程序導出可以寫成如下方式。

//初始化SqlDataAdapter

System.Data.SqlClient.SqlDataAdapter myDataAdapter = new System.Data.SqlClient.SqlDataAdapter();

//初始化SelectCommand ,其中strSQL為待執行的SQL語句,SQLconn為數據連接

myDataAdapter.SelectCommand = new System.Data.SqlClient.SqlCommand(strSQL,SQLconn);

//使用myDataAdapter初始化SqlCommandBuilder

System.Data.SqlClient.SqlCommandBuilder myCB = new System.Data.SqlClient.SqlCommandBuilder (myDataAdapter);

//初始化一個DataSet

System.Data.DataSet DS = new System.Data.DataSet();

//執行strSQL中的SQL指令,查詢結果填充到DS中

myDataAdapter.Fill (DS);

//從E:ExFromPC.XSD文件中導入XML架構

DS.WriteXmlSchema(E:ExFromPC.XSD);

//按照XML架構導出XML數據到E:ExFromPC.XML中

DS.WriteXml(E:ExFromPC.XML);

自此,XML文件已經導出完成,即可使用2.3所闡述的文件傳輸方式的任意一種傳輸到WinCE嵌入式系統中去。

3.2.WinCE端數據導入

//初始化DataSet

System.Data.DataSet DS = new System.Data.DataSet();

//初始化XML架構文件操作流

FileStream FsXSD = new FileStream(ExFromPC.xsd,FileMode.Open);

//初始化XML架構讀取設備

XmlTextReader xtrXSD = new XmlTextReader(FsXSD);

//載入XML架構到DS中

DS.ReadXmlSchema(xtrXSD);

//關閉XML架構讀取設備

xtrXSD.Close();

//關閉XML架構文件操作流

FsXSD.Close();

//按照裝載了的XML架構載入XML數據到DS

DS.ReadXml(ExFromPC.XML);

在載入完XML數據之后,即可通過種種方法把數據寫入到數據庫中,或交由其它方式處理,在此不再陳述。

3.3.WinCE端數據導出

//初始化DataSet

System.Data.DataSet DS = new System.Data.DataSet();

//初始化SqlCeDataAdapter

System.Data.SqlServerCe.SqlCeDataAdapter myDataAdapter = new System.Data.SqlServerCe.SqlCeDataAdapter();

//初始化SelectCommand ,其中conn是數據連接,p_strSQL待執行的SQL語句

myDataAdapter.SelectCommand = new System.Data.SqlServerCe.SqlCeCommand(p_strSQL,conn);

//初始化SqlCeCommandBuilder

System.Data.SqlServerCe.SqlCeCommandBuilder myCB = new System.Data.SqlServerCe.SqlCeCommandBuilder(myDataAdapter);

//加載映射的數據表名p_strTableNameTemp為數據表名

myDataAdapter.TableMappings.Add(Table,p_strTableNameTemp);

//把SQL語句執行結果寫入到DS中

myDataAdapter.Fill (DS);

//初始化XML架構文件操作流

FileStream FsXSD = new FileStream(ExFromPC.xsd,FileMode.Open);

//初始化XML架構讀取設備

XmlTextReader xtrXSD = new XmlTextReader(FsXSD);

//載入XML架構

DS.ReadXmlSchema(xtrXSD);

//關閉XML架構讀取設備

xtrXSD.Close();

//關閉XML架構文件操作流

FsXSD.Close();

//導出XML數據文件

DS.WriteXml(ExFromPC.xml);

自此,XML文件已經導出完成,即可使用2.3所闡述的文件傳輸方式的任意一種傳輸到PC中去。

3.4.PC端XML數據導入

//初始化架構文件操作流

FileStream FsXSD = new FileStream(E:ExFromCE.XSD,FileMode.Open);

//初始化XML數據文件操作流

FileStream FsXML = new FileStream(E:ExFromCE.XML,FileMode.Open);

//初始化DataSet

System.Data.DataSet DS = new System.Data.DataSet();

//初始化XML架構讀取設備

XmlTextReader xtrXSD = new XmlTextReader(FsXSD);

//載入XML架構

DS.ReadXmlSchema(xtrXSD);

//關閉XML架構讀取設備

xtrXSD.Close();

//關閉XML架構文件流



關鍵詞:

評論


相關推薦

技術專區

關閉