谈一谈重 ORM 和 轻 ORM + SQL 的一些经验
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 的一些经验的更多相关文章
- 谈一谈Elasticsearch的集群部署
Elasticsearch天生就支持分布式部署,通过集群部署可以提高系统的可用性.本文重点谈一谈Elasticsearch的集群节点相关问题,搞清楚这些是进行Elasticsearch集群部署和拓 ...
- 谈一谈对MySQL InnoDB的认识及数据库事物处理的隔离级别
介绍: InnoDB引擎是MySQL数据库的一个重要的存储引擎,和其他存储引擎相比,InnoDB引擎的优点是支持兼容ACID的事务(类似于PostgreSQL),以及参数完整性(有外键)等.现在Inn ...
- 蓝的成长记——追逐DBA(5):不谈技术谈业务,恼人的应用系统
***************************************声明*************************************** 个人在oracle路上的成长记录,当中 ...
- 谈一谈Java8的函数式编程(二) --Java8中的流
流与集合 众所周知,日常开发与操作中涉及到集合的操作相当频繁,而java中对于集合的操作又是相当麻烦.这里你可能就有疑问了,我感觉平常开发的时候操作集合时不麻烦呀?那下面我们从一个例子说起. 计 ...
- ORM的概念, ORM到底是什么
一.ORM简介 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术.简单的说,ORM是通过使 ...
- 谈一谈泛型(Generic)
谈一谈泛型 首先,泛型是C#2出现的.这也是C#2一个重要的新特性.泛型的好处之一就是在编译时执行更多的检查. 泛型类型和类型参数 泛型的两种形式:泛型类型( 包括类.接口.委托和结构 没有泛型枚 ...
- 从一张图开始,谈一谈.NET Core和前后端技术的演进之路
从一张图开始,谈一谈.NET Core和前后端技术的演进之路 邹溪源,李文强,来自长沙.NET技术社区 一张图 2019年3月10日,在长沙.NET 技术社区组织的技术沙龙<.NET Core和 ...
- ORM基础之ORM介绍和基础操作
一.ORM介绍 1.ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过 ...
- 谈一谈iOS事件的产生和传递
谈一谈iOS事件的产生和传递 1.事件的产生 发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中. UIApplication会从事件队列中取出最前面的事件,并将事件 ...
随机推荐
- 排序---希尔排序Java
希尔排序 插入排序的一种又称“缩小增量排序”,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减 ...
- Xamarin图表开发基础教程(11)OxyPlot框架支持的图表类型
Xamarin图表开发基础教程(11)OxyPlot框架支持的图表类型 OxyPlot组件中支持7种类型的条型图表,分别为普通条形图.线型条形图.矩形条形图.差值图.龙卷风图.普通柱形图和柱形误差图, ...
- Java基础 throw 抛出异常后,用try...catch捕获
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Android adb临时关闭Selinux
在eng/userdebug版本中 使用getenforce 命令查询当前权限状态,如:adb shell getenforce 使用setenforce 命令进行设置:adb shell seten ...
- Python中request的post请求报requests.exceptions.SSLError:
今天发送一个post请求,提示错误 requests.exceptions.SSLError: HTTPSConnectionPool(host='user.zaful.com', port=443) ...
- SVN限制普通用户删除文件及提交时必须填写log日志
SVN用得也算挺广泛的,但是它也存在着一个大问题,就是权限控制得比较差,要么读,要么读写,而读写就意外着可以删除文件(目前我的理解是这样,如果有什么不对的地方,请多指教). 刚好前段时间发生了开发人员 ...
- python 可变数据类型 和 不可变数据类型
在 python 中,类型属于对象,变量是没有类型的: a=[1,2,3] a="Runoob"以上代码中,[1,2,3] 是 List 类型,"Runoob" ...
- PCL
PCL(PointCloudLibrary)——是一个的模块化的现代C++模板库. 其基于以下第三方库:Boost.Eigen.FLANN.VTK.CUDA.OpenNI.Qhull,实现点云相关的获 ...
- FPGA程序编译后逻辑单元数为0
问题 FPGA代码写完后编译不报错,但是显示使用的逻辑单元数(Total logic elements)为0.当然程序也不工作. 我用的是Intel Altera FPGA,verilog语言,在Qu ...
- js arguments
偶然碰见一个有意思的题 <script> var length = 10; function fn() { console.log( this.length ); // 10 } var ...