主流ORM对比分析,莫人云亦云

目前主流的ORM框架有Entity Framework,Dapper,NHibernate,NBear,Castle ActiveRecord,BATIS.NET六种,都是免费开源的。下边从官方支持性,数据库支持性,开发周期,运行效率几方面进行对比。

1.1         官方支持性

Entity Framework,Dapper,NHibernate,Castle ActiveRecord,BATIS.NET五种都有官方支持,NBear已经停止更新,因此NBear不在使用之列。

1.2         数据库支持性

主流的ORACLE,MSSQL,MYSQL三种主流数据库官方提供对Entity Framework的支持,其余4种均为第三方公司提供的框架。

1.3         开发周期

Entity Framework不需要编写配置文件,不需要编写sql语句,有代码生成器,可直接使用原始项目的实体文件;

Dapper类似于Entity Framework  codefirst模式,但是需要在数据库访问层编写sql语句;

NHibernate需要编写配置文件,开发周期最长;

Castle ActiveRecord 基于NHibernate开发,改用Attribute来代替配置文件,没有本质的区别;

iBATIS.NET与NHibernate类似,需要编写配置文件。

1.4         运行效率

NHibernate系的效率的最低的,没有任何的疑问!

很多人毫无疑问的会认为Dapper的效率最高,其基于Emit开发,但是在实际的性能测试中Entity Framework效率最高(参看http://www.cnblogs.com/bluedoctor/p/3378683.html)。

通过综合的分析,Entity Framework最适合做数据库持久层。

ORM与ado.net对比

绝大多数人会认同网上广为传播的说法,因为铺天盖地的orm弊端已经广为深入人心。现在对其进行批驳:

1、orm大量使用反射,拖慢效率

如果现在还有人提这种说法,说明这种人是多么的out,或者这种人不能胜任技术,转行做了管理。泛型委托+反射+缓存的机制很早就已经解决了这个问题。

2、orm要先生成sql语句,这个过程慢

我觉得统一这种观点的人根本就没有在应用程序中写过sql。因为sql基本都是通过拼凑字符串,很多人都是通过+=来做的,而且根本就不会写优秀的sql语句,你写的sql语句在oracle性能测评工具中是*sql吗?高校的查询分页有几个人会写? orm都是有官方支持的,是会翻译成最*的sql去执行的!你在开发中不会用到实体?

3、懒

很多人停留在老技术,老风格的层面,学了c,认为优秀的开发语言都应该c风格的,对与语言化的linq总是持否定态度,net2.0 是多少年前的了?

4 眼高于头顶

应届毕业生普遍存在的现象,不多说了!

上一篇:Mysql高级之存储过程


下一篇:List内存分配