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的方法而我没有发现,如果你知道,请一定留言告诉我。

   测试的源码从此处下载。



目录
相关文章
|
13天前
|
SQL 数据库 开发者
MSSQL性能调优实战技巧:索引优化、SQL语句微调与并发控制策略
在Microsoft SQL Server(MSSQL)的管理与优化中,性能调优是一项复杂但至关重要的任务
|
13天前
|
SQL 监控 数据库
MSSQL性能调优实战策略:索引优化、SQL语句重构与并发控制
在Microsoft SQL Server(MSSQL)的管理和优化过程中,性能调优是确保数据库高效运行、满足业务需求的重要环节
|
13天前
|
SQL 监控 数据库
MSSQL性能调优实战技巧:索引优化策略、SQL查询重构与并发控制详解
在Microsoft SQL Server(MSSQL)的管理与优化过程中,性能调优是确保数据库高效运行的关键环节
|
13天前
|
SQL 监控 数据库
MSSQL性能调优实战指南:精准索引策略、SQL查询优化与高效并发控制
在Microsoft SQL Server(MSSQL)的性能调优过程中,精准索引策略、SQL查询优化以及高效并发控制是三大核心要素
|
3天前
|
SQL DataWorks 关系型数据库
DataWorks产品使用合集之数据集成时源头提供数据库自定义函数调用返回数据,数据源端是否可以写自定义SQL实现
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
2天前
|
SQL 分布式计算 DataWorks
MaxCompute操作报错合集之使用sql查询一个表的分区数据时遇到报错,该如何解决
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
|
13天前
|
SQL 运维 监控
MSSQL性能调优实战技巧:索引优化、SQL查询优化与并发控制策略
在Microsoft SQL Server(MSSQL)的运维过程中,性能调优是确保数据库高效运行、满足业务需求的关键环节
|
11天前
|
SQL 数据库
【SQL】已解决:SQL分组去重并合并相同数据
【SQL】已解决:SQL分组去重并合并相同数据
22 1
|
1天前
|
SQL 存储 Oracle
TDengine 3.3.2.0 发布:新增 UDT 及 Oracle、SQL Server 数据接入
**TDengine 3.3.2.0 发布摘要** - 开源与企业版均强化性能,提升WebSocket、stmt模式写入与查询效率,解决死锁,增强列显示。 - taos-explorer支持geometry和varbinary类型。 - 企业版引入UDT,允许自定义数据转换。 - 新增Oracle和SQL Server数据接入。 - 数据同步优化,支持压缩,提升元数据同步速度,错误信息细化,支持表名修改。 - 扩展跨平台支持,包括麒麟、Euler、Anolis OS等。
9 0
|
11天前
|
SQL 测试技术 数据库
【SQL】已解决:SQL错误(15048): 数据兼容级别有效值为100、110或120
【SQL】已解决:SQL错误(15048): 数据兼容级别有效值为100、110或120
19 0