开发者社区> zhuweisky> 正文

DataRabbit 轻量的数据访问框架(14)-- DataRabbit 3.0 与 Linq to sql 性能比较

简介: 今天装好了VS2008 Beta2,就迫不及待地试用一下Linq中的ORM功能,在初步尝试后,发现Linq中的ORM还是非常不错的,通过反射查看System.Data.Linq.dll发现,Linq中的ORM是使用反射完成了OR的映射工作,基于此,我开始有点怀疑Linq中的ORM的性能问题。
+关注继续查看
   今天装好了VS2008 Beta2,就迫不及待地试用一下Linq中的ORM功能,在初步尝试后,发现Linq中的ORM还是非常不错的,通过反射查看System.Data.Linq.dll发现,Linq中的ORM是使用反射完成了OR的映射工作,基于此,我开始有点怀疑Linq中的ORM的性能问题。为了进一步研究问题,我写了一个简单的测试,在事务中,使用DataRabbit 3.0和 Linq to sql 以ORM的方式分别向数据库的Customer表中插入1000条数据,来看各自所需的时间。
   首先,Customer结构如下:
   
   测试的代码如下:
(1)使用Linq ORM:
            DataClasses1DataContext db = new DataClasses1DataContext("Data Source=127.0.0.1;Initial Catalog=LinqDb;Persist Security Info=True;User ID=sa;Password=chenqi");

            DateTime start 
= DateTime.Now;
            
for (int i = 1000; i < 2000; i++)
               {
                      db.Customers.Add(
new Customer { ID = i, Name = "Peng", ZipCode = 434100
 });
               }
            db.SubmitChanges();

            DateTime end 
= DateTime.Now;
            TimeSpan span 
= end - start;
            
this.label1.Text = span.TotalSeconds.ToString(); 


(2)使用DataRabbit3.0的ORM

            DataRabbit.DataConfiguration config = new DataRabbit.DataConfiguration(DataRabbit.DataBaseType.SqlServer, "127.0.0.1""sa""chenqi""LinqDb"null);
            DataRabbit.Application.TransactionScopeFactory transactionScopeFactory 
= new DataRabbit.Application.TransactionScopeFactory(config);
            transactionScopeFactory.NewTransactionScope(
false).NewOrmAccesser<LinqTest.MyOrm.Customer>().Insert(new LinqTest.MyOrm.Customer(-1"Peng"434100));


            DateTime start 
= DateTime.Now;
            
using (DataRabbit.Application.TransactionScope scope = transactionScopeFactory.NewTransactionScope())
            {
                DataRabbit.ORM.IOrmAccesser
<LinqTest.MyOrm.Customer> accesser = scope.NewOrmAccesser<LinqTest.MyOrm.Customer>() ;
                   
                
for (int i = 2000; i < 3000; i++)
                   {
                          accesser.Insert(
new LinqTest.MyOrm.Customer(i, "Peng"434100
));
                   }

                scope.Commit();
            }
            
            DateTime end 
= DateTime.Now;
            TimeSpan span 
= end - start;
            
this.label2.Text = span.TotalSeconds.ToString(); 



   清空Customer的内容,第一次点击Form的按钮(先linq,后DataRabbit)后,界面显示如下:


   再次清空Customer的内容,第二次点击Form的按钮(先linq,后DataRabbit)后,界面显示如下:

   和结果一相比,我们发现linq ORM在运行时作了一些非常有效的优化,性能提升了将近一倍。如果再重复试验,会发现Linq和DataRabbit所需的时间基本上不再变化。

   从稳定的结果看来,DataRabbit3.0的ORM性能比Linq要高出将近一倍,出现这样的结果,也是我意料之中的吧。DataRabbit3.0采用Emit动态生成程序集可以完全避免反射所带来的性能损失,而Linq to sql的内部采用反射实现ORM而导致性能稍微下降则是情理之中的了。
   Linq使用反射实现ORM的一个地方如下所示:

   (System.Data.Linq.ChangeDirector+StandardChangeDirector的Insert方法实现)

   也许,也许还有更高效使用Linq ORM的方法而我没有发现,如果你知道,请一定留言告诉我。

   测试的源码从此处下载。



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
浏览器输入域名网址访问后的过程详解
我们从系统网络的角度分析在浏览器输入域名网址访问后的过程:
111 0
DLA如何分析Table Store的数据
数据湖(Data Lake)是时下热门的概念,基于数据湖,可以不用做任何ETL、数据搬迁等过程,实现跨各种异构数据源进行大数据关联分析,从而极大的节省成本和提升用户体验。
950 0
Sql性能检测工具:Sql server profiler和优化工具:Database Engine Tuning Advisor
原文:Sql性能检测工具:Sql server profiler和优化工具:Database Engine Tuning Advisor 一、工具概要     数据库应用系统性能低下,需要对其进行优化,     如果不知道问题出在哪里,可以使用性能检测工具sql server profiler。
1777 0
Web Vitals :Google 如何定义性能指标及帮助开发者调优前端性能 ?
来自 Google 的Palances Liao 将在第十五届 D2 前端技术论坛带来 《以全球 Web 角度谈前端性能的更新与趋势》主题演讲,与大家分享关于 Core Web Vitals 的最新指标及每个指标的更新。
1550 0
数据同步框架MS Sync Framework - IDE快速开发支持Local Database Cache
数据同步框架MS Sync Framework [术语、例子、参考资料、Tips] http://www.cnblogs.com/2018/archive/2011/02/22/1961654.html  数据同步框架MS Sync Framework-不同场景使用例子和简要分析 http://www.cnblogs.com/2018/archive/2011/02/23/1961657.html 以上两篇文章对框架的基础有了描述,通过IDE的提供Local Database Cache可以快速的实现一个常用的同步应用。
797 0
简单易用高性能!一文了解开源迁移学习框架EasyTransfer
近日,阿里云正式开源了深度迁移学习框架EasyTransfer,这是业界首个面向NLP场景的深度迁移学习框架。该框架由阿里云机器学习PAI团队研发,让自然语言处理场景的模型预训练和迁移学习开发与部署更加简单和高效。本文将对EasyTransfer进行深度解读。开源地址:https://github.com/alibaba/EasyTransfer
3270 0
+关注
zhuweisky
从事软件开发行业十多年,专注于网络通信技术和网络语音视频技术,擅长系统架构设计、系统性能优化等。zhuweisky.cnblogs.com
300
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载