database - .NET CF 移动设备应用程序 - 处理潜在离线性的最佳方法?

原文 标签 database web-services windows-mobile compact-framework offline

我正在 VB.NET(紧凑框架)中构建一个移动应用程序,我想知道在设备上处理潜在离线交互的最佳方法是什么。基本上,这些设备具有蜂窝网络和 802.11,但可能仍处于离线状态(接收效果不佳等)。司机离开卡车时会扫描箱子,我想更新新位置 - 如果有网络信号,立即更新,或者如果离线并稍后处理,则排队。不过,这让我开始思考如何处理一般的离线性。

  • 我是否将尽可能多的数据缓存到设备中,以便在离线时使用它 - 本质上,每个设备上都会有(相关)生产数据的副本?还是在离线时禁用某些功能更好,以避免以后同步的麻烦?我知道这是一个非常具体的问题,取决于我的应用程序,但我很想知道其他人是否已经采取了这条路线。
  • 我是否构建应用程序本身以使其始终处于离线状态,将所有内容提交到本地类拥有的各种本地队列(基本上抽象掉在线/离线内容),然后让类将内容提交到服务器作为它可以?数据查找怎么样 - 如何以“半实时”方式处理这些?
  • 或者我应该让应用程序尝试直接、实时地向服务器提交请求,并在它本身请求失败时进行处理?我可以看到让用户等待超时的潜在问题,但这是最可靠的方法吗?

  • 我不是在寻找特定的解决方案,而实际上只是关于开发人员如何以最流畅的用户体验实现这一目标的故事,以及指向操作方法或此处考虑的内容或类似内容的链接。感谢您在这方面的指点!

    最佳答案

    我们无法给您一个明确的答案,因为没有适合所有使用场景的“正确”答案。例如,如果您在后端使用 SQL Server 并在本地使用 SQL CE,您总是可以设置合并复制并让数据引擎为您处理所有这些。那很干净。使用离线应用程序块可能会解决它。使用存储转发可能是一种选择。

    您可以在本地存储,然后使用检测到网络时使用的 WCF 服务的直接连接、Web 服务滚动您自己的同步。您可以使用 MSMQ 进行交付。

    您需要考虑的不是“正确”的方式是什么,而是您的实现将如何影响应用程序的可用性。如果由于缺乏连接而禁用功能,该应用程序是否仍然可用?如果您有陈旧的数据,这是一个问题吗?当您使用 GSM/GPRS(通常不是免费的)时,可能需要传输一些关键数据,而使用 802.11 时需要传输更多数据。也许您可以整天运行查找表,早上拉下查找表并只上传交易,设备会跟踪它所做的更改。

    基本上它真的取决于它的使用方式、数据的性质、现场设备之间数据交易的重要性、数据延迟的影响,以及我无法立即想到的其他因素。

    因此,第一步是确定需要如何使用应用程序,然后确定基础设施和架构以提供所需的连接性和数据访问。

    关于database - .NET CF 移动设备应用程序 - 处理潜在离线性的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/224496/

    相关文章:

    web-services - 真实交易API

    java - SQL-锁定或不锁定:选择下一个未使用的代码

    database - Postgresql中的约束

    c# - 比较 Entity Framework 模型

    java - 避免在RPC(SOAP)API之间进行中间数据转换?

    c# - 如何确定Windows Mobile中的程序中断

    android - 获取数据库行中的所有数据以显示Android SQLite

    web-services - Hadoop前面的服务

    c++ - UnregisterHotKey()在Windows Mobile上不起作用

    c++ - Windows Mobile/C:WAITING变量更改