- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想在用户从每个字段中跳出时,通过 Web API 保存 WPF 移动应用程序中编辑的值。所以在 LostFocus 事件上。
当使用 EF 时,每次更新字段时,整个实体图都会发布(放入)到 Web API。即使我只是为表单上的基本字段创建一个 DTO,我仍然会每次都发布不必要的数据。
我正在考虑忘记 Web API 中的 EF,而只是发布实体 ID、字段名称和新值。然后在 Controller 中,创建我自己的 SQL 更新语句并使用旧的 ADO.Net 更新数据库。
这听起来像是回到了 20 世纪 80 年代甚至 90 年代,但我有什么理由不应该这样做吗?
我已阅读 this post这让我倾向于我提出的解决方案。
感谢任何意见或建议
最佳答案
听起来您正试图从拥有 RESTful Web API 转向更像 RPC 的东西。这很好,只要您对实现它的额外麻烦在节省带宽方面是值得的感到高兴。
就技术水平而言,您并没有因为按照您的建议而倒退;我每天都使用 EF,但我仍然经常需要时不时地使用普通的旧式 ADO.NET
,这也是它在 CLR 中得到良好支持的原因。所以没有理由不这样做,只要你能熟练地编写 SQL 等。
但是,出于几个原因,我反对你目前的提议
即使对于移动设备,一次发回 20 或 30 个字段的数据量可能也不是很多。当然,只有您知道您的具体情况是否太多,但考虑到 3 和 4G 网络的广泛可用性,除非这些字段包含大量数据,否则我不认为这是一个问题 - 当然,它是你的用例让你最了解 :)
除非表单实际上是几个可以独立更新的离散对象的表示,否则每次更新字段时发回单独的更改,您将面临设备上出现无效状态的风险。
例如,如果 User A
和 User B
都在他们的设备上查看同一个对象。这个对象有 3 个字段 A, B, C
因此:
A-"FOO"
B-"42"
C-"12345"
Now suppose User A changes field "A" to "BAR" and tabs out of the field, and then User B changes field "C" to "67890" and tabs.
您的后端现在具有该对象的此状态:
A - "BAR"
B - "42"
C - "67890"
但是,用户 A
和 用户 B
现在对象的状态都不正确!
It gets worse if you also have a facility to re-send the entire object from either client because if
User A
re-sends the entire form (for whatever reason)User B
's changes will be lost without any warning!
通常这就是交换完整状态的 RESTful 机制运作良好的原因;您将整个对象发送回服务器,并根据完整状态来决定是否应该覆盖最新版本,或者返回错误,或者返回提示用户手动操作的状态合并更改等。
换句话说,它允许您有意义地处理冲突。例如,Entity Framework 将通过包含一个特殊类型的列来免费为您提供并发检查;您可以处理并发异常来决定要做什么。
Now, if it's the case that the form is comprised of several distinct entities that can be independently updated, you have more of a task-based scenario so you can model your solution accordingly - by all means send a single Model to the client representing all the properties of all of the individual entities on the form, but have separate POST back models, and a handler for each.
例如,如果表单显示客户主数据及其对应的地址记录,您可以向客户发送单个模型来填充表单,但仅在客户主字段更改时发送客户主模型,并且仅发送地址地址字段更改等时的模型。这样您就可以吃蛋糕了,因为您的 POST 有效载荷较小并且您可以管理并发性。
关于c# - 为什么要在移动环境中使用 Entity Framework?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29913337/
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicates: What is a framework? What does it do? Why do we need a f
我在按照 http://msdn.microsoft.com/en-us/data/jj591621.aspx 处的 Microsoft Data Developer 过程启用代码优先迁移时遇到了一些
我正在从 迁移项目 Entity Framework 4.3 在 .net 4 上运行到 Entity Framework 5 在 .net 4.5 上运行。在不做任何更改的情况下,当我尝试运行该项目
我正在使用 Entity Framework 6 并使用 EntityFramework Extended 来执行一些批量更新和批量删除。批量更新和批量删除工作正常,但我还需要知道更新/删除的实体(即
我在实体上添加了一个列,然后从模型中生成数据库或构建解决方案,然后收到一条消息,提示我刚添加的新列未映射。该数据库以前是从模型创建的,没有错误。 当我右键单击Entity并选择Table Mappin
每次我尝试运行我的代码时都会崩溃,因为我尝试启动函数以调用 SDK 的任何部分。 我在构建过程中包含了 FoundationSDK: 并且我在头文件中包含了对 SDK 的引用: 但是每次我运行这个,我
我以前能够毫无问题地提交我的申请。我的工作流程中唯一改变的部分是使用 Sourcetree。在对以下框架进行更新后,我在提交到 iOS App Store 时收到此警告。我还收到一封电子邮件,其中包含
假设我为 Asp.NET Web 应用程序安装了 .NET Framework 2.0、3.0、3.5。 我意识到 Framework 3.0 和 3.5 只是 Framework 2 的扩展,不太清
是否有 SaveChanges 事件在保存更改后但在更新更改跟踪器之前触发? 我正在使用 EF 6。 我需要在某个实体的状态发生变化时执行任务。 我已经覆盖了 SaveChanges 来设置它。我可以
我正在使用一个现有的数据库,并且我已经将其中一个表映射为一个实体(因为我需要映射一个外键)。 因此,在初始化此数据库时,我希望 EF 忽略此实体,因为它已经存在。 我该怎么做? 最佳答案 您应该使用
我有 3 个表需要与 Entity Framework 进行映射,但我不确定解决此问题的正确方法。这是我的 3 个实体: public class User { [Key] public
我首先使用 VS 2010 和 Entity Framework 代码(版本 6)。我有两个实体,每个实体都在自己的上下文中,我想在它们之间创建一对多关系。 上下文 1 具有以下实体: public
我知道 EF 在 CodePlex 上是开源的,但我没有看到当前发布的 5.0 版本的分支。我在哪里可以得到这个源代码? 最佳答案 没有。他们只开源了 post 5 版本。第一次签到可能足够接近,但再
我们目前有一个数据库很大的系统,存储过程既用于CUD又用于查询。数据集用于从 SP 查询中检索结果。 现在我们正在研究使用 Entity Framework 针对同一个数据库开发另一个项目。在查询数据
我有一个每 10 秒运行一次的 Windows 服务......每次运行时,它都会获取一些测试数据,对其进行修改并使用 EntityFramework 将其保存到数据库中。但是,在每一秒运行时,当我尝
我对在我们的场景中仅将 Entity Framework 与存储过程一起使用的合理性有疑问。 我们计划拥有一个 N 层架构,包括 UI、BusinessLayer (BLL)、DataAccessLa
当我使用 Entity Framework 时,我想在上下文中查询出一条记录并将其添加到具有相同架构的另一个上下文中,在查询出记录后,我将其从上下文中分离出来,但是相关实体都没有了,是吗?有什么办法解
我正在使用 Entity Framework 5 构建 ASP.Net MVC4 Web 应用程序。我必须使用现有的 sql server 数据库,但也想使用 Code First,所以我遵循了本教程
在 Entity Framework 4.0 中使用 T4 模板创建 POCO 会丢失什么?为什么使用 Entity Framework 4.0 时的默认行为不创建 POCO? 最佳答案 你会失去很多
我在网上使用 Repository Pattern 和 EF 看了很多例子。但他们都没有真正谈到与相关实体的合作。 就像说用户可以有多个地址。 IUserRepository User CreateU
我是一名优秀的程序员,十分优秀!