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

  最近文档写了不少,导致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

image

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

image

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

image

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

image

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

image

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

image

【测试总结】

   第一阶段测试结果非常出人意料,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并用其访问数据库时各种操作所占的时间比

PerfBlogImage2_thumb

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

无标题_thumb

我 们可以使用EDMGen2.exe来自己生成View.cs,然后把它加入到工程中编译,这样会大大缩减View Generation操作所占的时间比。根据ADO.NET TEAM 的测试,自己编译View大概会节省28%的时间。不过我在自己电脑上测试的结果没有那么理想,大概是8%左右。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值