您的位置:首页 > 数据库

(转)ADO.net,Linq to SQL和Entity Framework性能实测分析

2011-10-20 11:06 459 查看
  最近文档写了不少,导致Word和Excel的使用能力飞一般成长。考虑到项目中读写数据库的方法存在效率不高,以致影响用户体验的问题,决定测试一下Microsoft新推行的Linq和EF能不能在效率上有所改进。

  测试环境当然就是我这台笔记本了,受限与硬盘转速,运行起来一定是不如台式机的,但至少保证了三个方案相同的软硬件环境:Windows Server 2008,Visual Studio 2008,MS SQL Server 2008,清一色的最新产品。

  测试分成六个阶段,数据量分别为10,10,100,1千,1万,10万逐级增长,分别测试了读取、写入、更改、删除四个基本的操作的耗时,结果如下(时间单位:秒):

第一次读写10条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)0.0070.350.020.0140.09775
LINQ to SQL0.0230.0830.1020.0680.069
Entity Framework0.2383.0840.0090.0060.83425


第二次读写10条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)0.0020.0340.0110.0200.01675
LINQ to SQL0.0030.0110.0430.0580.02875
Entity Framework0.0040.0060.0050.0040.00475


操作100条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)0.0050.2020.1030.0620.093
LINQ to SQL0.0030.0830.3500.2980.1835
Entity Framework0.0040.0350.0300.0210.0225


操作1000条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)0.0442.0861.0560.7200.9765
LINQ to SQL0.0060.8053.0352.9251.69275
Entity Framework0.0100.3920.2960.2090.22675


操作10000条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)0.43521.06910.3286.9259.68925
LINQ to SQL0.027、97329.98528.89116.71725
Entity Framework0.0294.1423.3212.4342.47925


操作100000条数据
读写方式读取耗时添加耗时修改耗时删除耗时平均耗时
当前机制(简化)4.525213.603100.66882.203100.25
LINQ to SQL0.20780.789305.912290.481169.347
Entity Framework0.38742.40238.49724.3626.4115


【测试总结】

   第一阶段测试结果非常出人意料,ADO.net和LINQ to SQL操作数据的时间都控制在0.5秒以内,非常的迅速,但是Entity Framework在添加这步表现非常差,由于这五步是连续测试,其中添加数据是第一步操作,而EF在在进行第一步操作的时候足足延迟了3秒钟!这3秒钟 到底EF在做什么?

  从第二阶段开始,性能的优劣就非常明显的展现在我们面前,第二阶段到第六阶段,不论操作数据量的大小,图中的耗 时比例几乎是相同的。Entity Framework无可争议的以极高的效率在三种方案中脱颖而出,而LINQ to SQL的龟速修改和删除操作消耗的时间几乎是EF的10倍,ADO.net在添加数据上的表现实在不尽如人意,这也跟我们项目底层写法有关。

  从上面的测试结果可以看出,除去EF在初次操作数据是延迟的3秒钟(初步认为是初始化时间),EF的平均效率是LINQ to SQL的6倍,是当前项目机制的4倍,这是非常可观的效率提升,不难理解为什么微软几乎放弃了LINQ to SQL,全力支持EF了。

【深入分析为什么第一次执行Entity Framework非常慢的原因】(转)

第一次创建ObjectContext并查询数据时耗费了大量的时间,原因是什么?有没有什么优化的方法?本文将给出一个合理的解释。

下面这个饼状图给出了第一次创建ObjectContext并用其访问数据库时各种操作所占的时间比






从中可以看出仅仅View Generation一个操作就占用了56%的时间,不过令人欣慰的是,这个操作只出现在第一次查询的时候,之后生成好的View会被缓存起来供以后使用。一个View.cs文件的样本如下:






我 们可以使用EDMGen2.exe来自己生成View.cs,然后把它加入到工程中编译,这样会大大缩减View Generation操作所占的时间比。根据ADO.NET TEAM 的测试,自己编译View大概会节省28%的时间。不过我在自己电脑上测试的结果没有那么理想,大概是8%左右。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: