gpt4 book ai didi

entity-framework - Entity Framework 添加对象似乎导致了严重的性能问题,如何解决?

转载 作者:行者123 更新时间:2023-12-03 00:14:45 24 4
gpt4 key购买 nike

我正在使用 EF6 和 POCO。我遇到了性能问题,并将其定位到以下代码中的 AddObject 行。所有其他线路都需要很短的时间。使用本地数据库

var myOrderList = db.Order.Where(r => r.SupplierId== mySupplier.Id).OrderBy(r => r.Id).ToList(); //Local 5ms Azure 40ms.

foreach (Order myOrder in myOrderList)
{
var myOrderItem = new OrderItem
{
OrderId = myOrder.Id,
ProductId = product.Id
};
db.OrderItem.AddObject(myOrderItem); //Local 20ms Azure 300ms.
}

db.SaveChanges(); //Local 12ms Azure 40ms.

因此,AddObject 似乎存在固有的性能问题,尤其容易受到 Azure 问题的影响。

关于如何解决此 AddObject 性能问题的想法?不确定为什么会发生这种情况。

谢谢。

编辑1

在 Azure 中,我针对 SQL Azure(Web 版)使用 Azure 网站(中型)。我的本地(开发)设置由同一台计算机上 WIndows 7 上的 IIS 和 SQL Server 2008 SP2 组成。

最佳答案

我在向 MS SQL Server 添加大量项目时遇到了类似的问题。我最终使用了 ExecuteSqlCommand,它要快得多。
但这只是将数据添加到数据库中,而不是添加到 EF 对象中 - 对于您的情况,这可能是问题,也可能不是问题。

http://msdn.microsoft.com/en-us/library/system.data.entity.database.executesqlcommand(v=vs.113).aspx

关于entity-framework - Entity Framework 添加对象似乎导致了严重的性能问题,如何解决?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27955402/

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