知识大全 Microsoft .NET Compact Framework 数据访问策略

Posted

篇首语:黄金的宝藏比不上知识的宝藏。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 Microsoft .NET Compact Framework 数据访问策略相关的知识,希望对你有一定的参考价值。

Microsoft .NET Compact Framework 数据访问策略  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

   简介  从设备的角度 本文的讨论重点在于 Pocket PC 平台 但是 Microsoft® NET Compact Framework 也可以在非 Pocket PC 的 Microsoft Windows® CE NET 设备上运行 此处讨论的 NET Compact Framework 相关概念也可以适用于这些设备      NET Compact Framework 数据访问策略涉及许多方面 关键方面是连接 其他各个方面都取决于此 由于 Pocket PC 既可以联机使用也可以脱机使用 因此数据访问策略需要定义如何     在联机时管理和使用远程服务器上的数据   在脱机时存储和使用数据   在 Pocket PC 从先前的脱机状态进入联机状态时交换数据   在数据访问策略环境中 建立标准术语非常重要 标准术语的建立对于如何定义 Pocket PC 和服务器之间的数据交换尤其重要 从概念的角度 交换数据的方法有两种 数据同步和数据传输     数据同步支持双向的数据交换 并实现确保两端数据相同的功能 在很多情况下 同一数据可以在 Pocket PC 处于脱机状态时在多个地方进行修改 然后与服务器同步 因此 同步功能常常需要包含冲突解决功能 以处理在断开连接的 Pocket PC 返回到联机状态以同步数据时发生的并发性问题 下面的示例说明了四处走动的推销员在脱机状态下实地更新订单时发生的这种情况 在推销员同步更改之前 一位联机客户服务代表也对同一订单进行更新 设计周到的冲突解决机制能够在出现冲突时决定应采取何种措施 例如 基于同步的角色或时间使四处走动的推销员覆蓋客户服务代表 或者系统是否应通知用户或用户组出现了冲突     数据传输也支持双向的数据交换 但是却没有用于确保两端数据相同的功能 也没有冲突解决 在很多情况下 数据传输是有效的方法 并且不需要数据同步 数据传输的示例有 将静态引用数据从服务器传输到 Pocket PC 仅将新收集的数据从 Pocket PC 传输到服务器 以及将明确引入和引出或分段到单个用户的数据传输到 Pocket PC 或从 Pocket PC 传出 并在数据被引出或由特定用户拥有时在服务器上将其标为只读数据     在这一点上 术语 数据同步 和 数据传输 反应了它们真实的含义 而在同时包含这两个术语时 则使用 数据交换      数据访问策略的各个方面  在根本上 NET Compact Framework 数据访问策略涉及两个方面     如何在 Pocket PC 上存储数据 从应用程序的角度来看 数据可以保存在关系数据库(例如 Microsoft SQL Server&# ; CE) 本地文件(例如通常通过 DataSets 管理的 XML 文件)以及在应用程序终止时配置的基于会话的内存内数据结构中   如何与服务器交换数据 Pocket PC 和服务器之间数据交换的执行方式根据进行通信的 Pocket PC 层与服务器层的不同而有所差异 图 说明了 Pocket PC 中的三个层以及服务器中的三个层    >   >   NET Compact Framework 自身包含的数据交换选项包括     Pocket PC 数据库对服务器数据库 Pocket PC 数据库与服务器数据库直接交换数据 此选项在涉及很少业务逻辑或不涉及业务逻辑以及在数据量很大的情况下有效 并使用 SQL Server CE 的远程数据访问(英文)和合并复制(英文)功能来执行 如果要求进行数据同步而不仅仅是数据传输 则合并复制功能可以提供在服务器端的 SQL Server 调节程序中执行的内部冲突解决   Pocket PC 组件对服务器组件 Pocket PC 应用程序与服务器上的组件进行通信 此选项能使业务逻辑(作为 Web 服务 [英文] 执行)成为数据交换的一部分 当数据保存在本地的 XML 文件或 SQL Server CE 数据库中时 均可使用此选项   Pocket PC 组件对服务器数据库 Pocket PC 直接连接到服务器数据库 在 Pocket PC 应用程序需要管理远程数据库的大量数据 而不必将数据放入 Pocket PC 以及业务逻辑不是主要的考虑因素时 经常使用此选项 此选项使用 System Data SqlClient(英文)命名空间执行 在数据保存在本地的 XML 文件和 SQL Server CE 数据库时均可使用   仅在服务器上交换数据 Pocket PC 应用程序用户界面元素可以直接连接到服务器端的组件或作为使用 Pocket PC Web 浏览器的 Web 应用程序执行 显然 这要求 Pocket PC 始终连接到服务器并需要足够的带宽 该选项可行的实例是地理环境受限制 但可以实现 WiFi 网络的情况 例如在仓库 保健机构 办公室中等等 此选项不要求将所有数据存储在 Pocket PC 本地   在确定如何处理 如何存储数据 和 如何交换数据 这两个方面之前 必须了解或建立某些基本条件 数据特性 连接和系统结构      数据特性  解决方案的数据特性显示了以下重要信息     要存储在 Pocket PC 上的静态数据及事务性数据的量 如果要存储在 Pocket PC 上的数据量少(在本例中为少于 至 kb) 则数据可以存储在本地的 XML 文件中 如果数据量较大 则 SQL Server CE 将提供较高的性能及可靠性 原因是 将使用 SQL Server CE 查询引擎访问数据 该查询引擎支持具有更高性能和可管理性的结构查询语言 (SQL)   要与服务器交换的事务性数据的量 如果要在服务器和 Pocket PC 之间交换的事务性数据的量少(例如少于 kb 至 Mb) 则可使用 Web 服务将数据作为 XML 传递 如果数据量较多 则远程数据访问和合并复制功能将提供较高的性能 原因是 SQL Server CE 客户端代理和服务器代理将执行有效的数据压缩 而且数据在到达最终目的地之前必须经过的进程要少得多 例如 在使用远程数据访问将数据从 Pocket PC 传输到服务器时 数据无需经过 Pocket PC 端的 OLEDB CE CLR/NET CF SQL Server CE 数据提供程序和 ADO NET 层 当数据传输到服务器时 也无需经过服务器上相应的这些程序 而是 数据可以从客户端代理直接传递到服务器代理 也可以通过 Internet Information Server 直接传递到远程 SQL Server   请务必注意 如果数据被存储为本地 XML 文件 则可以使用 Web 服务进行数据交换 如果数据存储在 SQL Server CE 中 也可能使用 Web 服务 而不是远程数据访问和合并复制 其原因包括使用了业务逻辑和现有的系统结构策略(可能适合)      连接  解决方案的连接方面涉及 Pocket PC 联机时的可用带宽以及 Pocket PC 的联机频率问题 这些因素有时可以作为前提条件给定 有时也可以进行定义和控制     由于 XML 通常包含大量未经压缩的重复元数据 因此 对于相同的数据 Web 服务比 SQL Server CE 远程数据访问和合并复制需要更多的带宽 但事实表明 当需要交换大量数据时 调用的是远程数据访问和合并复制的功能设置 另外 在数据交换频率低时也经常使用这两种方法 这可能会提高需要交换的数据量 这意味着 在现实中 SQL Server CE 远程数据访问和合并复制常用于高带宽的情况 而 Web 服务常用于低带宽的情况 因此 在使用 Web 服务时 聊天式 (大量小请求)设计比 区块式 (少量大请求)设计更适合      系统结构  系统结构方面涉及系统集成的总体问题 移动解决方案可以看成是与现行系统或现行系统的扩展和核心部分相连接的独立解决方案 然而 Pocket PC 解决方案通常不是独立的 因为它们需要与其他系统进行通信 因此 如果没有系统结构 则必须定义系统结构 如果已有系统结构 则应遵守     目前 大多数系统均作为技术界面驱动的多层解决方案实现 服务器端的应用程序已被组件化 以便启用代码的重复使用以及业务逻辑和数据的分离 并提高可管理性 XML 和 Web 服务的使用继续推动该项开发 并且 NET Compact Framework 应用程序由于对 XML 和 Web 服务消费的本地支持而完全适应此结构     另两种系统集成实现方式是使用队列的异步消息和数据库驱动集成 通过将 Web 服务界面用于服务器端的 MSMQ 队列 或通过在 Pocket PC 和服务器之间使用 Web 服务以及在服务器和后备办公室系统之间使用队列 NET Compact Framework 应用程序可以遵守这些实现方式 数据库驱动的集成是 SQL Server CE 的固有部分 这一点我们已经讨论过      代码演练  让我们看一些演示如何执行上面提到的选项的示例代码 源代码来自一个称为 Feedback Anyplace 的示例应用程序(用在一个称为 Architect Webcast:Designing Integrated Pocket PC Applications with NET Compact Framework [英文] 的 Webcast 中) 演示了质检人员可以如何使用 Pocket PC 在捕获并报告生产中的问题 该示例需要使用 IntelliProg 的 RichInk 控制才能运行 您可以下载源代码 包括 NET Compact Framework 应用程序 Web 服务和数据库组件 该示例项目是数据传输而非数据同步的示例      在 Pocket PC 上存储数据  下列代码演示了如何将类似于类的属性包存储到 DataSet 和本地 XML 文件中     Public Sub Save()   保存新项目或更新现有项目   Dim ds as DataSet  Dim dr As DataRow  Dim expr As String = ID = + m_ID +     If m_NewItem Then     将新行添加到表    dr = frmMain ds Tables( Feedback ) NewRow()  Else     查找现有行     使用 Select 方法查找与过滤器匹配的行    dr = frmMain ds Tables( Feedback ) Select(expr)( )  End If     设置数据行属性  dr( ID ) = m_ID< cha138/Article/program/net/201311/13997

相关参考

知识大全 .NET Compact Framework 的类库信息

.NETCompactFramework的类库信息  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!l

知识大全 .NET Compact Framework下的注册表开发

.NETCompactFramework下的注册表开发  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧

知识大全 为 .NET Compact Framework 开发能够识别方向和 dpi 的应用程序[2]

为.NETCompactFramework开发能够识别方向和dpi的应用程序[2]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内

知识大全 为 .NET Compact Framework 开发能够识别方向和 dpi 的应用程序[1]

为.NETCompactFramework开发能够识别方向和dpi的应用程序[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内

知识大全 Microsoft .NET的优势与劣势

Microsoft.NET的优势与劣势  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!    NET

知识大全 Microsoft .NET 框架资源基础

Microsoft.NET框架资源基础  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  摘要Chr

知识大全 Microsoft .NET 中的基类继承

Microsoft.NET中的基类继承  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  继承概述 

知识大全 Microsoft .NET Framework安全概述

Microsoft.NETFramework安全概述  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 Microsoft .NET Remoting技术概述

Microsoft.NETRemoting技术概述  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 

知识大全 Microsoft .NET 中的简化加密(2)(图)

Microsoft.NET中的简化加密(2)(图)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!