gpt4 book ai didi

c# - 用 Entity Framework 替换 ADO.NET。 Entity Framework 适用于以下场景吗?

转载 作者:太空宇宙 更新时间:2023-11-03 13:25:06 25 4
gpt4 key购买 nike

问题 1:我们应该在多用户环境中使用 Entity Framework 来实现对表执行多次更新(100 行)的功能吗?

问题 2:我们在以下情况下使用 EF 的决定是否正确?

场景 Stock Count 网页包含一个可编辑的 gridview 控件,允许用户一次更新 100 行。

背景库存盘点用于记录期末库存数量。所有组织的期间关闭发生在星期一。大约有 10 个现场组织,平均每个组织至少有 100 多个网站在周一同一时间进行股票关闭。

基于 ADO.NET 的类似屏幕运行良好。然而,该团队正在尝试在新屏幕上引入 Entity Framework。我们进行了方法级别的压力测试,但没有为 EF 获得有希望的结果。我们运行了 2 分钟的测试并模拟了从 5 个用户到 35 个用户的用户负载。

结果如下:

ADO.NET 使用存储过程一次更新一个数据库。

5 Users - Number of test per second per user - 80
35 Users - Number of test per second per user - 150

EF 使用 SaveChanges() 方法,该方法在内部一次更新一个数据库。

5 Users - Number of test per second per user - 43
35 Users - Number of test per second per user - 43

EF代码:

方法一

context.Configuration.AutoDetectChangesEnabled = false;
context.Set<LocationData>().AddRange(data); //data is a collection of LocationData
foreach (var locationData in data)
{
var entry = context.Entry(locationData);
entry.State = EntityState.Modified;
}
context.SaveChanges();

方法 1 的代码分析器详细信息

enter image description here

方法二

context.Configuration.AutoDetectChangesEnabled = false;
foreach (var locationData in data)
{
context.Set<LocationData>().Attach(data);
var entry = context.Entry(locationData);
entry.State = EntityState.Modified;
}
context.SaveChanges();

方法 2 的代码分析器详细信息

enter image description here

Entity Framework 生成的SQL查询

exec sp_executesql N'
UPDATE [dbo].[LocationData]
SET [LocationId] = @0, [ClientId] = @1, [ProductId] = @2,
[SupplierProductId] = @3, [MenuId] = @4, [MenuNumber] = @5, [CaskNumber] = @6
WHERE ([Id] = @7)',N'@0 bigint,@1 bigint,@2 bigint,@3 bigint,@4 bigint, @5 bigint,@6 nvarchar(64),@7 bigint',
@0=22371851,@1=22371851,@2=22371851,@3=22371851,@4=22371851,@5=22371851,@6=N'Cask0091',@7=22371851

ADO.NET 生成的 SQL 查询

Update LocationData
set
LocationId = @LocationId,
ClientId= @ClientID,
ProductId= @ProductId,
SupplierProductId=@SupplierProductId, MenuId= @MenuId,
MenuNumber= @MenuNumber,
CaskNumber= @CaskNumber
WHERE LocationData.Id = @Id

这些测试不是在事务下执行的。

我在开发中使用了以下工具:Visual Studio 2012 Ultimate、Sql Server R2、Entity Framework 6.0.2、.NET 4.5、C#

最佳答案

没有。 Entity Framework 简化了大型模型架构,并自动生成 SQL 来处理困难的“复杂”部分。如果您将 EF 用于简单的读/写实用程序类型目的,则最好使用 ADO.NET。如果您希望标准化和简化一组开发人员使用您的 SQL Server 的方式,您应该使用 Entity Framework 。

关于c# - 用 Entity Framework 替换 ADO.NET。 Entity Framework 适用于以下场景吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22675162/

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