ORM 的本质比较简单,就是对象关系映射 Object Relation Mapping

那很多人都经常会说的一个问题,EF 或 EF Core 好啊,方便啊,不用写麻烦的 SQL ,写 SQL 又要提高成本(初级程序员的学习成本)又会降低代码可读性。

我个人总结的经验就是不用纠结太多,看项目,也看侧重点。

用 EF / EF Core 好处:

  1. 上手快,开发容易,LINQ & Lambda 写法可读性高

  2. 学习成本低(很重要)

缺点也很致命:

  1. 不易掌控,很容易写出效率极低的 LINQ 导致拖死 DB。

  2. 过度屏蔽细节,真的要用好 EF 需要深入了解其内部架构

  3. 依赖官方更新,如果存在 BUG 或优化,没有非常了解的小组,很被动

个人推荐的使用场景:

  1. 公司有几个或1个专门的小组对 EF / EF Core 有深入研究,并且可以做二次开发

  2. 中小型,内部项目,并且不存在性能要求(高并发,大数据量的数据查询,DB压力很小)也可以用

Dapper + Sql 好处(推荐):

  1. 快,稳,可控性高(细节把控) 。

  2. 可扩展性强,毕竟就那么点东西,不过需要懂 Emit,不写 Emit 封装可能存在性能问题,毕竟 ORM 需要做大量反射。

  3. 有实际项目在用,Stackoverflow 那么大的并发量都能抗住,说明本身是一个优秀的开源项目。

缺点:

  1. 首先需要学 SQL ,虽然不是一门语言,但是是一个必要技能,有一部分初学者接触过 EF 后,产生一种不需要写 SQL 的感觉。目前来讲不是很赞同(以后可能会有 AI 分析,我也不确定)

,程序员,就是要有知其然知其所以然的精神,至少自己写的 SQL,自己知道 SQL 执行了哪些东西,分析问题也容易(总不至于连发现几个 SQL 查询非常慢,你一脸大写懵逼,还要去找 DBA 帮忙)。

  2. 需要合理的写 SQL,如果写在代码中,会降低代码可读性(如果 SQL 比较长)

  3. Dapper 本身只做了 ADO.Net 的封装,所以你需要比写 EF 做更多的事情,比如连接池管理。

个人推荐场景:

  1. 对 SQL 性能有一定要求(甚至有些公司有非常严格的要求,查询用时要精确到毫秒),并且经常需要分析 SQL 日志做数据库方面的优化。

  2. 团队中对写 SQL 不排斥,毕竟不能强人所难吧,有一些人确实不喜欢写 SQL (虽然我不这么认为)。

  3. 数据量很大,并发也不小,但又不是很想在 ORM 这个方面做过多投入。

谈一谈重 ORM 和 轻 ORM + SQL 的一些经验的更多相关文章

  1. 谈一谈Elasticsearch的集群部署

      Elasticsearch天生就支持分布式部署,通过集群部署可以提高系统的可用性.本文重点谈一谈Elasticsearch的集群节点相关问题,搞清楚这些是进行Elasticsearch集群部署和拓 ...

  2. 谈一谈对MySQL InnoDB的认识及数据库事物处理的隔离级别

    介绍: InnoDB引擎是MySQL数据库的一个重要的存储引擎,和其他存储引擎相比,InnoDB引擎的优点是支持兼容ACID的事务(类似于PostgreSQL),以及参数完整性(有外键)等.现在Inn ...

  3. 蓝的成长记——追逐DBA(5):不谈技术谈业务,恼人的应用系统

    ***************************************声明*************************************** 个人在oracle路上的成长记录,当中 ...

  4. 谈一谈Java8的函数式编程(二) --Java8中的流

    流与集合    众所周知,日常开发与操作中涉及到集合的操作相当频繁,而java中对于集合的操作又是相当麻烦.这里你可能就有疑问了,我感觉平常开发的时候操作集合时不麻烦呀?那下面我们从一个例子说起. 计 ...

  5. ORM的概念, ORM到底是什么

    一.ORM简介         对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术.简单的说,ORM是通过使 ...

  6. 谈一谈泛型(Generic)

    谈一谈泛型 首先,泛型是C#2出现的.这也是C#2一个重要的新特性.泛型的好处之一就是在编译时执行更多的检查. 泛型类型和类型参数 ​ 泛型的两种形式:泛型类型( 包括类.接口.委托和结构 没有泛型枚 ...

  7. 从一张图开始,谈一谈.NET Core和前后端技术的演进之路

    从一张图开始,谈一谈.NET Core和前后端技术的演进之路 邹溪源,李文强,来自长沙.NET技术社区 一张图 2019年3月10日,在长沙.NET 技术社区组织的技术沙龙<.NET Core和 ...

  8. ORM基础之ORM介绍和基础操作

    一.ORM介绍 1.ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过 ...

  9. 谈一谈iOS事件的产生和传递

    谈一谈iOS事件的产生和传递 1.事件的产生 发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中. UIApplication会从事件队列中取出最前面的事件,并将事件 ...

随机推荐

  1. nacos启动与sql8.0的问题解决方法

    hi all! 半年多没更新,是不是以为我消失了……直接正题~ 在搭建nacos环境的时候,有这样的一项:数据库持久化配置.(官方文档),这个配置可以灵活的帮我们进行配置而不用总是重启服务. 那么问题 ...

  2. tmp 字典合并

    tmp  

  3. 000 okhttp3的Get使用

    一:概述 1.说明 java与android都可以使用. 是网络请求的开源框架. square公司开发,用于替代HttpUrlConnection和Apache  HttpClient 2.优点 支持 ...

  4. git如何查找已经被删除文件的历史修改记录?

    答: 使用以下命令即可: git log --all --full-history -- <path-to-file>

  5. DateUtil(2)

    import java.sql.Timestamp; import java.text.ParseException; import java.text.SimpleDateFormat; impor ...

  6. [LeetCode] 314. Binary Tree Vertical Order Traversal 二叉树的垂直遍历

    Given a binary tree, return the vertical order traversal of its nodes' values. (ie, from top to bott ...

  7. [LeetCode] 774. Minimize Max Distance to Gas Station 最小化加油站间的最大距离

    On a horizontal number line, we have gas stations at positions stations[0], stations[1], ..., statio ...

  8. Java之浮点数运算

    浮点数运算和整数运算相比,只能进行加减乘除这些数值运算,不能做位运算和移位运算. 在计算机中,浮点数虽然表示的范围很大,但是浮点数有个非常重要的特点,就是浮点数常常无法精确表示 举例 浮点数0.1在计 ...

  9. bugclose使用—bug管理工具

    1.前言 bugclose管理的是BUG,而不仅仅是bug.BUG概念是bugclose的创造,代表团队工作的对象,包括缺陷,任务和需求. 2.bugclose访问地址 访问地址:https://ww ...

  10. IFC文件介绍

    IFC是一个数据交换标准, 用于不同系统交换和共享数据. IFC是采用EXPRESS语言定义的实体关系模型,由几百个实体对象组成.实体对象包括建筑要素如IfcWall,几何元素如IfcExtruded ...