zoukankan      html  css  js  c++  java
  • 主流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 眼高于头顶

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

  • 相关阅读:
    枚举
    log4j 简单应用
    [luogu4728 HNOI2009] 双递增序列 (dp)
    [luogu3760 TJOI2017] 异或和(树状数组)
    [luogu1485 HNOI2009] 有趣的数列 (组合数学 卡特兰数)
    [luogu4054 JSOI2009] 计数问题(2D BIT)
    [luogu2594 ZJOI2009]染色游戏(博弈论)
    [luogu2591 ZJOI2009] 函数
    [luogu2148 SDOI2009] E&D (博弈论)
    [luogu2154 SDOI2009] 虔诚的墓主人(树状数组+组合数)
  • 原文地址:https://www.cnblogs.com/zuolijun/p/5124203.html
Copyright © 2011-2022 走看看