WinCE中基于XML的数据同步
来源:爱问科技网 作者: 时间:2007-07-30 发布人:
谭欣
摘 要:在不同的操作系统中,系统与系统之间的数据交换是最为重要的环节,在此,由W3C制定出来的XML正是针对不同系统之间的数据交换而设计,基于WinCE嵌入式系统,完全支持W3C的XML的最新规范,因此,XML作为WinCE嵌入式系统数据同步的媒介是比较理想的选择。本文主要介绍在.NET开发平台下,WinCE中基于XML的数据同步的方式和方法。
关键词:XML;XSD;.NET;C#;WinCE;存储卡;无线网;GPRS;PDA;SQL CE;.NET FrameWork
1.引言
在此,我们利用WinCE 3.0的Pocket PC 2002和Windows XP之间的数据同步来阐述本文,为了实现数据同步,我们在Pocket PC 2002中加载了SQL CE作为Pocket PC的数据库,在XP中加载了SQL Server 2000作为普通台式计算机的数据库,同时采用了Visual Studio .NET 2003作为研究的开发平台,Pocket PC与普通PC计算机之间的数据同步采用XML方式进行,XML数据文件传输方式采用存储卡、红外、无线网、GPRS等任意一种方式进行。
XML是为在 Web 上传送而进行优化了的 SGML 的子集。它是由万维网联合会 (W3C) 定义的。该标准化确保了结构化数据的统一性和相对于应用或供应商的独立性。XML 是一种提供数据描述格式的标记语言。该语言使跨越多个平台进行更准确的内容声明和获得更有意义的搜索结果变得更加容易。此外,XML实现了表示与数据的分离,通过应用不同的样式表和应用程序,使您能够根据需要显示和处理数据。XSD是XML 架构定义语言,可为 XML 文档定义结构和数据类型。XML 架构是由顶级 schema元素组成的。
2.设计要点
设计要点是通过XML方式进行不同系统之间多元数据类型、多元数据表的双向数据交换。PC与PDA之间的数据传输可以使用存储卡形式,也可以使用无线网形式,无线网包含无线局域网(802.11)、GPRS、CDMA、红外线(IRQ)等多种模式。在此,各种无线网或各种存储卡或许只能称为是一种媒介,它们存在的目的只是为了传输XML交换文件到不同的系统。数据交换的模型图如图1所示
2.1.XML交换文件设计
在此我们使用XML文件作为传输数据的交换文件,因此XML交换文件的设计是最为重要的一个步骤,通俗来说,一个XML交换文件包含两个部分,一个是XML架构,也就是XSD,另外一个是XML的数据部分。在.NET的智能设备(smart device)开发中必须使用.Net FrameWork的精简版,之所以称之为精简版,只是因为它是普通的.Net FrameWork的子集,因此它并不支持所有的普通模式下的功能,针对XML来说,它必须把XML的数据和XML的架构(XSD)分开,或许是微软为了考虑传输的文件大小的问题吧,因为在众多的应用中,架构一般不会改变,而且都是已知的架构,只传输XML数据总是比还要传输XML架构来的小。下面我们分步来讲解这两个部分。
2.1.1.XML架构(XSD)设计
在此我们所涉及到XSD,则主要是针对这个XML文件的架构制定遵循的版本和所涉及到的数据的类型。
在此,我们举例要描述数据表“T_Message”。
同时它包含两个字段:
MessageID int
MessageTitle varchar(128)
按照XSD的规范,我们就可以得到如下的架构。
<?xml version="1.0" standalone="yes"?>
<xs:schema id="NewDataSet" xmlns=""
xmlns:xs=http://www.w3.org/2001/XMLSchema
xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="NewDataSet" msdata:IsDataSet="true"
msdata:Locale="zh-CN">
<xs:complexType>
<xs:choice maxOccurs="unbounded">
<xs:element name="AT_ShippingProperty">
<xs:complexType>
<xs:sequence>
<xs:element name="MessageID"
type="xs:int" minOccurs="0" />
<xs:element name="MessageTitle"
type="xs:string" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
从以上可以看出,XSD描述了这个XSD的版本是1.0,属于w3c制定的架构等等信息,同时还描述了MessageID和MessageTitle两个字段,为了看得更明白,我们采用了加粗表示。
2.1.2.XML数据
在此我们所涉及到XML数据内容部分,则主要是针对这个XML文件所遵循的版本和数据的字段内容。
在此,我们举例要描述数据表“T_Message”。
同时它包含两个字段:
MessageID int
MessageTitle varchar(128)
假设这个数据表中存有两条记录,如下表所示:
MessageID
MessageTitle
1
数据库连接
2
数据库操作
按照XML的数据规范,我们就可以得到如下的XML数据。
<?xml version="1.0" standalone="yes"?>
<NewDataSet>
<AT_Public_Message>
<MessageID>1</MessageID>
<MessageTitle>数据库连接</MessageTitle>
</AT_Public_Message>
<AT_Public_Message>
<MessageID>2</MessageID>
<MessageTitle>数据库操作</MessageTitle>
</AT_Public_Message>
</NewDataSet>
2 .2.嵌入式系统
嵌入式系统一般指非PC系统,它包括硬件和软件两部分。硬件包括处理器/微处理器、存储器及外设器件和I/O端口、图形控制器等。软件部分包括操作系统软件(OS)(要求实时和多任务操作)和应用程序编程。有时设计人员把这两种软件组合在一起。应用程序控制着系统的运作和行为;而操作系统控制着应用程序编程与硬件的交互作用。
当前主流的嵌入式系统的操作系统(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架构文件流
FsXSD.Close();
//初始化XML数据读取设备
XmlTextReader xtrXML = new XmlTextReader(FsXML);
//导入XML数据到DS中
DS.ReadXml(xtrXML);
//关闭XML数据设备
xtrXML.Close();
//关闭XML数据文件流
FsXML.Close();
在读取XML数据到DS之后,即可通过种种手段写入到数据库中,在此不再陈述。
用XML方式同步数据,可以达到一次同步多个数据表的功能,为离线方式同步数据库的首选,可以适用于多种场合,比如Windows和Linux之间同步数据,Windows和UNIX之间同步数据。
分享到:
相关推荐
在WinCE系统中,开发应用程序时可能会遇到各种问题,包括同步问题。本篇文章主要讨论的是如何解决WinCE的同步问题,特别是针对编程实现的资源管理同步。 1. **内存不足问题**: 当在调试WinCE应用程序时,系统可能...
WinceAPI则是Windows CE系统的核心编程接口,它为开发者提供了丰富的函数和结构体,用于创建应用程序、管理硬件资源、处理系统事件等。本篇文章将深入探讨Windows CE API开发的相关知识点。 一、Windows CE API概述...
在Windows CE .NET环境下,开发AD7854驱动程序是一项关键任务,因为AD7854是一款高精度的模拟到数字转换器(ADC),广泛应用于各种嵌入式系统,如工业控制、医疗设备和数据采集系统。这篇文章将深入探讨如何在WinCE...
根据提供的文件信息,本文将对S3C6410在WinCE6.0环境下的...通过本篇文章,我们深入了解了S3C6410在WinCE6.0环境下的按键中断驱动程序的设计原理及其实现方法,这对于从事嵌入式系统开发的工程师具有一定的参考价值。
在软件层面,文章强调了在WinCE下编写CAN驱动程序的关键步骤,包括设备注册、中断处理、数据发送和接收函数的实现等。通过这些功能,可以实现对CAN网络的实时监控和控制,满足移动焊接机器人对控制响应速度的要求。 ...
Windows CE(简称WINCE)是微软开发的一个实时嵌入式操作系统,主要用于掌上设备、工业控制设备等。在WINCE系统中,驱动程序是连接硬件和操作系统的核心组件,确保操作系统能够正确识别和管理硬件资源。本篇文章将为...
### WinCE环境搭建过程 #### 一、WinCE概述与特点 Windows CE(简称WinCE)是微软开发的一款嵌入式操作系统,具有高度定制性、灵活性以及...希望本篇文章能为那些希望进入WinCE开发领域的初学者们提供一定的帮助。
在IT行业中,RSS阅读器是一种常见的工具,它用于订阅和管理网络...以上就是关于“Rss阅读器 和WinCE开发有关”的核心知识点,涵盖了从RSS技术本身到Windows CE平台开发的多个层面,希望对理解和开发此类项目有所帮助。
本篇文章将详细探讨如何在WinCE6中开发和使用SPI驱动。 首先,SPI驱动的基本原理:SPI是一种全双工、同步的通信协议,它通过四条信号线——主设备(Master)的数据输出(MOSI)、主设备的数据输入(MISO)、时钟...
总之,WinCE进程共享内存是系统级编程中的一个重要话题,理解其工作原理和使用方法对于开发高效、可靠的嵌入式应用程序至关重要。在实际应用中,开发者需结合具体需求和系统资源,合理设计和实现共享内存方案。
在Windows CE(WinCE)操作系统中,开发应用程序时,经常需要在不同的窗体之间进行数据交换和通信。这种通信机制是实现程序功能的关键部分,尤其是在多窗口应用中。本篇文章将详细探讨WinCE窗体间通讯的核心概念、...
在上一篇文章《VS2005 windows moblie 开发环境配置》中,我们已经解决了通过Windows Mobile 5.0的仿真器上网的问题。但是后来我发现没法浏览本地的网页。开始的时候,我想是不是仿真器无法浏览VS2005创建的虚拟目录...
WinCE线程同步原理设计是嵌入式系统开发中的关键概念,尤其在基于Windows Embedded Compact (WinCE)的操作系统上。WinCE是一个支持多任务的优先级调度系统,能够同时运行多个功能强大的进程。在这个系统中,每个进程...
本篇文章将围绕WinCE平台下的C#双缓冲技术展开讨论,通过对示例代码进行解析,帮助读者深入理解该技术的应用方式。 #### 二、双缓冲原理 双缓冲是指在图形渲染过程中使用两个缓冲区:一个用于后台绘制操作,另一个...
本文将聚焦于在WinCE环境下,基于三星的ARM9内核芯片S3C2410上的CAN总线控制器SJAl000的流接口驱动程序设计。 CAN(Controller Area Network)总线是一种高效的串行通信协议,尤其适合于工业控制和汽车电子应用,...
然而,在WinCE环境下,由于缺乏相应的UI库和控件,开发美观且定制化的界面变得尤为棘手。 1. 扩展标准控件 开发者通常会尝试通过扩展WinCE的标准控件,如CButton,来实现自绘功能,例如创建图片按钮或透明文字。...
本篇文章将深入探讨如何在WinCE系统下,利用MFC(Microsoft Foundation Classes)构建一个AT指令解析类,以便高效地处理这些通信任务。 AT指令是Hayes公司制定的一套标准命令,用于控制调制解调器和其他串行通信...
本篇文章将深入探讨“wince6.0五子棋游戏”的特点、设计思路以及可能涉及的关键技术。 五子棋,又称连珠,是双方对弈的游戏,目标是在棋盘上先形成连续的五个棋子(横向、纵向或斜向)的一方获胜。游戏简单易懂,但...
然而,文中提到的内容似乎与标题不完全相符,因为文章摘要和部分内容涉及的是数字图书中的版权水印检测算法,而不是直接讨论WinCE的多线程编程。这部分内容可能属于另一篇论文或者是一个错误的引用,与本文的主题...