ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

C#中的ORM框架

2021-04-05 18:31:16  阅读:378  来源: 互联网

标签:框架 C# 开源 ORM LR Error NET 2.1


1. 什么是ORM

ORM:对象关系映射(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping)

用于实现面向对象编程语言里不同类型系统的数据之间的转换

ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象与关系数据库相互映射
ORM可以解决数据库与程序间的异构性,比如:在C#中我们使用string表示字符串,而Oracle中可使用varchar2,MySQL中可使用varchar,SQLServer可使用nvarchar。

如果没有ORM我们原始代码如下:

LR_Error pLR_Error = new LR_Error()
{
    ErrorNum = Convert.ToInt32(dr[Table_LR_Error.T_LR_Error_F_ID]),
    GZBM = dr[Table_LR_Error.T_LR_Error_F_GZBM].ToString(),
    ParentPath = dr[Table_LR_Error.T_LR_Error_F_ParentPath].ToString(),
    FileExist = dr[Table_LR_Error.T_LR_Error_F_FileExist].ToString(),
};

2. 目前代码中的ORM都有哪些

2.1 C#中的ORM框架

  • SqlSugar (国内)
  • Dos.ORM (国内)
  • Chloe (国内)
  • StackExchange/Dapper (国外)
  • Entity Framework (EF) (国外)
  • NHibernate (国外)
  • ServiceStack/ServiceStack.OrmLite (国外)
  • linq2db (国外)
  • Massive (国外)
  • PetaPoco (国外)

2.1.1 SqlSugar

SqlSugar是国人开发者开发的一款基于.NET的ORM框架,是可以运行在.NET 4.+ & .NET CORE的高性能、轻量级 ORM框架,众多.NET框架中最容易使用的数据库访问技术。

  • 特点:

    • 开源、免费
    • 国内开发者开发、维护;
    • 支持.NET Core;
    • 支持主流数据库,如:SQL Server,MySql,Oracle,Sqlite等;
    • 维护更新及时

2.1.2 PetaPoco

PetaPoco:轻量的POCO对象和数据库映射的ORM框架。

  • 特点:

    • 开源、免费

2.1.3 linq2db

linq2db也是一款快速、轻量、类型安全的POCO对象和数据库映射的ORM框架。从构架上来说,linq2db是对比如:Dapper、PetaPoco这个的微ORM的进一步封装,但它不像Entity Framework那样笨重。它没有实现状态跟踪,需要自己处理实体的状态更改等。

2.1.4 Dos.ORM

Dos.ORM(原Hxj.Data)于2009年发布,2015年正式开源。在开发过程中参考了NBear与MySoft,吸取了他们的一些精华,加入新思想,同时参考EF的Lambda语法进行大量扩展。该组件已在数百个成熟项目中应用。官方网站:http://ITdos.com/Dos/ORM/Index.html

  • 特点:

    • 开源、免费
    • 上手简单,0学习成本。使用方便,按照sql书写习惯编写C#.NET代码。功能强大
    • 高性能,接近手写Sql
    • 体积小(不到150kb,仅一个dll)
    • 完美支持Sql Server(2000至最新版),MySql,Oracle,Access,Sqlite等数据库
    • 支持大量Lambda表达式写法,国产ORM支持度最高,开源中国ORM排行前三
    • 不需要像NHibernate的XML配置,不需要像EF的各种数据库连接驱动
    • 遵循MIT开源协议,除不允许改名,其它随意定制修改

2.1.5 ServiceStack.OrmLite

ServiceStack.OrmLite的目标是提供一种方便,无干扰,无配置的RDBMS无关类型的封装,与SQL保持高度的契合,展现直观的API,可以生成可预测的SQL。
ServiceStack.OrmLite的宗旨:Fast, Simple, Typed ORM for .NET

  • 特点:

    • 开源、收费(免费版只支持单个库10张表)

2.1.6 Entity Framework (EF)

ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案。该框架曾经为.NET Framework的一部分,但version 6之后从.NET Framework分离出来。

2.1.7 NHibernate

NHibernate是一个面向.NET环境的对象/关系数据库映射工具。对象/关系数据库映射(object/relational mapping,ORM)这个术语表示一种技术,用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。

  • 特点:

    • 开源、免费
    • 批量写入
    • 批量读/多重查询特性(我理解是在说Future?)
    • 批量的集合加载
    • 带有lazy=”extra”的集合
    • 集合过滤器和分页集合
    • 二级缓存(实际上NH的二级缓存貌似也很简单?)
    • 集成和扩展性
    • 代码自动生成,减少代码和sql的开发量,使开发人员摆脱开sql,ado.net和事务,缓存等底层

2.1.8 Massive

Massive:小巧,动态的微ORM框架。

标签:框架,C#,开源,ORM,LR,Error,NET,2.1
来源: https://blog.csdn.net/a13407142317/article/details/115445922

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有