gpt4 book ai didi

entity-framework - 将仅更改字段的部分对象发送到 Web API 和 Entity Framework

转载 作者:行者123 更新时间:2023-12-03 01:25:37 24 4
gpt4 key购买 nike

WebApi 和 EF POCO 可以很好地协同工作。我一直在思考的一个问题是,随着时间的推移,某些对象可能会变得非常大。它们可以具有许多映射回数据库中的列的属性。对于这些对象,很少会一次更新超过一两个字段,因此这就引出了一个问题,为什么需要所有字段完成从客户端到服务器再到数据库的完整行程。

一些 JavaScript 框架提供了是否将所有字段或仅更改的字段发送回服务器的选项,以便客户端干净简单。

从我看来,服务器端是一个更大的挑战。序列化程序将介入并尝试将某些 json 或 xml 映射到类型。例如,只要对象中的相应属性可为空,JSON.NET 就能很好地处理缺失值。

另一方面,将反序列化模型重新连接回 Entity Framework 是事情变得棘手的地方。 Controller 的默认 WebApi 模板只需一行即可完成:

db.Entry(user).State = EntityState.Modified;

这显然将整个对象设置为修改。当然可以将单个属性而不是整个对象设置为修改,我认为这意味着 EF 更聪明,并且只在 SQL UPDATE 中将修改后的属性发送回。

所以这里的问题是,我如何知道更新了哪些属性?我只在 Controller 方法中返回一个对象,因此我无法询问序列化器它引入了哪些属性(即使对于给定的序列化器来说这是可能的)。如果我有一个属性列表,那么我可以设置当前值及其状态以在 EF 中进行修改,希望这会产生干净的数据库查询。

另一个可能更明显的选择是首先从数据库检索我想要更新的对象,然后在检索到的对象上仅修改已更改的属性,或者如果 EF 支持它,也许我可以将其传递给它独立的对象并让它自己执行此操作。这并不是一个理想的选择,因为它确实意味着读取整个数据库,而练习的重点是效率。我们要做的就是用客户端的 http 效率和带宽来换取服务器上数据库的命中率。

所以对我来说,如果我想在服务器上执行此操作,我会陷入进退两难的境地。 WebApi 和 EF 完成了大部分工作,但代价是灵 active 。我正在寻找我没有提到的选项或角度,希望有一个简单的解决方案,不会放弃这两项伟大技术之一。

最佳答案

How do I know what properties are updated?

我认为您不会得到该信息。默认序列化程序不希望您想知道任何细节。它们的功能是为您提供一个对象,而它们正是这样做的。如果您想了解详细信息,则必须自己进行反序列化 - 这意味着编写反序列化器或在操作中接受原始消息并解析它。

您还可以尝试将一些跟踪硬编码到实体本身中,并“记录”在反序列化期间设置了哪些属性,但这取决于序列化程序是否有效,因为如果反序列化也设置了这些值,它将毫无用处。

当您使用整个实体时,EF 和 WebAPI 可以协同工作。一旦开始使用部分数据传输,您必须将自己的逻辑放入游戏中。

关于entity-framework - 将仅更改字段的部分对象发送到 Web API 和 Entity Framework ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12516526/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com