你的位置:首页 > ASP.net教程

[ASP.net教程]流行ORM产品优缺点分析


什么是ORM?

ORM的全称是Object Relational Mapping,即对象关系映射。它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的操作转化为对这些对象的操作。因此它的目的是为了方便开发人员以面向对象的思想来实现对数据库的操作。

ORM实现原理

¤对象到数据库的映射;
¤对象与数据库数据的互相转换;
 
重量级ORM

以EntityFramework、NHibernate为代表

¨优点
面向对象方式访问数据库,摆脱SQL
可移植性强,支持所有流行的数据库
面向接口的设计,可扩充性强
对事务、缓存(一级缓存)有良好的封装及配置
¨缺点
比较复杂,学习曲线大;
处理对象关联很容易出错;
不适合统计查询系统;
对于多表连查,复杂的sql实现比较复杂,而且有可能需要借助其他方案;
自动生成的sql查询执行效率低;
对于大数据量、高负载场景需要慎重考虑;
实现良好的二级缓存很困难,并且只能定制;
 
轻量级ORM
 
 

 

简介

License

优点

缺点

dapper

单文件、迷你orm框架,支持poco及动态类型

http://code.google.com/p/dapper-dot-net

Apache License 2.0

可以免费商用

执行效率高

单个文件,无其他依赖

使用poco时,属性与数据库表的映射无法灵活配置,难以实现Repository模式

Massive

单文件仅几百行代码,仅支持动态类型

http://blog.wekeroad.com/helpy-stuff/and-i-shall-call-it-massive

New BSD License

可以免费商用

执行效率高

单个文件,无其他依赖

无法使用poco

PetaPoco

单文件、迷你orm框架,支持poco

http://www.toptensoftware.com/petapoco

Apache License 2.0

可以免费商用

执行效率高

单个文件,无其他依赖

poco与数据库表的映射可以灵活配置

密集执行sql时有bug(已修复)

 
重点介绍以下PetaPoco
优点
开源、免费;
执行效率高;
一般仅由一个文件组成,代码量小;
支持poco及动态类型;
缺点

  对象关联、事务、缓存等高级特性支持较少。

PetaPoco特性
国内一家sns产品近乎,用的就是petapoco,具体代码情况,可以下载他们的免费源码版本了解一下关于petapoco的使用情况,源码地址:http://www.jinhusns.com/Products/Download?type=whp

 



特性

支持情况

POCO

支持

自增ID支持

支持

枚举类型支持

支持

事务

支持(但是要求事务内的操作必须在一个PetaPoco database 实例内)

Stored Procedures

支持

基于数据库自动生成POCO

支持

SQL跟踪

支持

支持SQL Server2005~2008r2

支持

支持MySQL

支持