- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
问题 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();
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();
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
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/
websocket的用途/场景 先总结:高即时性服务,比如聊天室的群聊,server顺序收到了张三,李四的消息,立即就推送给王五,不能让王五等半天。 Ajax也可以一秒一刷,让王五去问张三说话没,如果
前端的工作过程里,本地开发、提供测试环境,总得有个用着顺手的服务器软件,这个场景里nginx很流行。 介绍两个好用的配置项:rewrite try_files @xxxx rewrite 比较
我有一个场景的两个不同角度的 2 个视频文件,我想重建场景的 3D 估计。它类似于 3D 传感器的作用(例如 Kinect、PrimeSense)。我正在寻找一个库,甚至是一个完善的机器视觉算法,以便
我已阅读RebaseProject页面并尝试了一个不平凡的例子(不是对一个完整的分支进行 rebase )。这与 rebase D 的情况类似我场景B。 这是rebase之前的情况: default
有没有办法将我的场景保存在 JavaFx 应用程序中单独的 Java 文件中?我尝试过这样的事情: public class MyApp extends Application { pri
我有这样的场景:用户想要查看大量有关自己的信息。例如:年龄、姓名、地位、收入、工作、爱好、 child 的名字、妻子的名字、酋长的名字、祖父/祖母的名字。大约 50 个变量。他可以选择任何变量来显示信
我希望有人能帮助我解决这个问题:我有一个包含条目的表。我想执行查询并根据模式获取得分最高的记录。模式将是:如果我的话按原样出现,那么该条目的分数将是最高的。如果该单词出现在句子中,则该条目的分数将低于
我正在尝试在我的应用程序委托(delegate)方法中实现一些逻辑。了解当前正在运行哪种场景将非常有帮助。 [[CCDirector sharedDirector] runningScene] 返回当
好的,这是一个有趣的。我有 2 个表:tbl_notes、tbl_notes_categories 简单地说,tbl_notes 有一个 categoryid,我将 2 个表与该 ID 相关联。所以,
我有一个使用并行运行的 Specflow、selenium、NUnit 的测试解决方案在 AssemblyInfo 中添加了这个:[程序集:Parallelizable(ParallelScope.F
我正在尝试弄清楚如何在 SpriteKit 中添加更多场景。如果我在 GameViewController 中使用 SpriteKit 生成的行 if let scene = GameScene.un
目录 1、业务背景 2、场景分析 3、流程设计 1、业务流程 2、导入流程
我是 Unity 的新手,所以修复起来可能非常简单。我使用了一个 3D Google SketchUp 模型,我想让玩家环顾模型。 super 简单。 我添加了 3D 平面,添加了相机并更新了设置以支
我需要标记要跳过的某些测试。但是,有些测试是参数化的,我只需要能够跳过某些场景。 我使用 py.test -m "hermes_only" 调用测试或 py.test -m "not hermes_o
我已经开始使用 SpecFlow 并想知道是否可以在规范之间重用场景 基本上我的想法是这样的(我可能从根本上是错误的:)) 我编写了一项功能来验证导航。 功能:导航 I should be able
在编写验证输入表单上的信息的 BDD 场景时,您将如何列出规则。 选项是: 1) 每个规则一个场景 2)场景大纲,每个领域和规则的例子 我们如何说某些不在特定字符集中的无效内容,例如: 鉴于我输入了一
我们如何使用 StoryQ 来测试预期出现异常的场景? 最佳答案 就实际代码而言,在测试代码的 .Then 部分,您需要创建一个 Action 或 Func 来确定正在测试的内容,然后在代码的 .Th
完成快速初学者努力通过点击按钮向场景添加节点。 我知道我可以使用点击手势来获取点击坐标并执行点击测试,然后在点击的 3D 空间中放置一个对象。但是,我想在设备屏幕的中央显示一个球体或十字准线,当点击屏
如何在表格中传递空格? Background: Given the following books |Author |(here several spaces)
我正在尝试从 Eric Haines' Standard Procedural Database (SPD) 渲染“mount”场景,但折射部分就是不想配合。我已经尝试了所有我能想到的方法来修复它。
我是一名优秀的程序员,十分优秀!