目录

一,为什么选择SqlSugar?

在.net core ORM框架中,能选择的方案其实有很多,包括以下方案:

1,EF-Core

2,Dapper

3,FreeSql

4,SqlSugar

为什么最后选择了Sqlsugar 呢? 一个个来说,

首先是:EF-core

EF-core 一开始想法也是担心性能问题,大概在7年前 有尝试过一次EF,深深被EF的性能所折服

实在是太慢了,当然做一些小型项目,EF当然是体现不出性能差距的,但是谁又知道自己的“小项目”哪天不会随着

业务的发展变成“大项目” 呢? 所以,一开始对EF 以及EF-Core 没有好感,不过后来看了,EF-Core的官网介绍,

感观上发生了很大的变化, 总的来说就是:EF 和 EF-Core 完全是两个东西。

更准确的说是:.net Core  和  .net Famework 完全是两个东西。 这么说吧,  .net Core在性能上完全不怂 java,go,python,php

任何一种语言,再说.net 性能不好的,可以啪啪打脸了。

但是,我还是首先淘汰了,EF-Core。原因是,查百度各种ORM都拿EF-core 做性能测试,可以参考以下连接:

参考:https://www.cnblogs.com/kellynic/p/10557882.html

虽然,EF-Core 性能跟EF 不能同日而语,但是,网上黑EF-Core性能不好的,还是大把。

Dapper说:比其他ORM都快,尤其比EF-core快!

FreeSql说:比其他ORM都快,尤其比EF-core快!

SqlSugar说:比其他ORM都快,尤其比EF-core快!

难免让人感觉,选什么都好,就是不能选EF-Core。所以第一淘汰EF-core, 但是我还是想说:EF-core真的不慢!

EF-Core 官网:https://docs.microsoft.com/zh-cn/ef/core/get-started/?tabs=netcore-cli

其次就是:Dapper

Dapper,可以说是轻量级ORM的王者,用户群体也多,是我的第二选择,但是也是第二个被淘汰的。

原因很简单,官网打卡太慢了,而且英文网站查起来费劲。

哈哈,其实这根本算不得一个理由,但是要知道,其实我是第一次使用ORM框架,(以前开发框架是基于ADO.Net的纯sql框架)

好吧,我算是老古董了,关于我的经历可以看  目录  中的前言有讲,所以我需要一个可以快速上手,方便查询的ORM。

所以,我淘汰了Dapper。

Dapper官网:https://dapper-tutorial.net/dapper

再来是:FreeSql

关于FreeSql,说来也巧。FreeSql的开发者跟我在一个.net 交流群里,陆陆续续都有聊过天,但是我不知道他是FreeSql的开发者,

准确来说,我一直不知道FreeSql 这个东西,当我在群里说在选择一个ORM 开发框架的时候,他死命的推荐我用FreeSql, 人就是这样

也死命推荐我用,我越是不想搞,所以先天的产生了逆反的心理状态,我看了几篇关于FreeSql 的的文章之后,其实感觉FreeSql还是非常不错的,

另外,FreeSql 也将代码捐献给我了 Core 中国 开源社区。

.net Core 开源中国社区:https://github.com/dotnetcore

我还是满佩服他的,搞出这么大个东西,还要坚持维护,不过我还是淘汰FreeSql了。最终理由是,书写的风格不没有Sqlsugar好。

不过FreeSql 是开源的,这个非常重要。

FreeSql官网:https://github.com/dotnetcore/FreeSql/

最后是:SqlSugar

按上面的先后顺序,SqlSugar是我排最后的,反倒最后被我选用了,理由只有一个:足够简单

当然,看我前面的淘汰理由,基本上毫无标准可言,全凭个人喜好。要知道,个人喜好就是唯一标准,对我来说

上手要快,开箱即用。Dapper ,EF-Core 其实都足够简单,尤其是EF-core,官方的文档相当齐全,视频更是讲的非常细致

最后,发现视频,文档 那么多,上手不够快呀,打卡SqlSugar是官网,上面一下就吸引我了,“一分钟入门”,“两分钟深入”,“三分钟高手”。

所以,最后就选定了SqlSugar。

SqlSugar官网:http://www.codeisbug.com/Doc/8

总结: 其实在性能上,都差不太多,不要老说EF-core慢 或者 哪个哪个快的,最关键是.net Core 快就行了。剩下的比拼就是个人对于上手的理解速度

以及代码的书写风格。这就是我最后选择SqlSugar 的原因。 都不慢,都挺好。

下一篇,  SqlSugar 的搭建。点击   目录   进行跳转吧!

手把手撸套框架-ORM框架的选择的更多相关文章

  1. 手把手撸套框架-Victory框架1.1 详解

    目录 上一篇博客 Victory框架1.0 详解  有说道,1.0的使用过程中出现不少缺点,比如菜单不能折叠,权限没有权限组等等. 所以,我还是抽出时间在下班后,回到我的小黑屋里 完成了1.1的升级. ...

  2. 手把手撸套框架-Victory框架1.0 详解

    目录 其实Victory框架1.0 在8月份就完成了,整个9月份都没有更新博客,主要还是因为松懈了. 所以,趁着国庆节的放假的时间把博客给更新一下,1.0总的来说算不得一个成熟的产品,但是拿来开发我们 ...

  3. 干货--手把手撸vue移动UI框架: 滑动删除

    前言 前几天因为项目需要,用jquery写了一个swiperOut组件,然后我就随便把这个组件翻译成基于Vue的了,有兴趣的朋友可以看下.Github源码(不麻烦的话帮忙start,请各位大爷赏个星星 ...

  4. 自定义ORM框架(转转)

    ORM背景 在数据库界,主流的数据库都是关系型数据库,其采用的关系型数据结构模型,无论从数学上还是实践中都相当的成熟,得到非常广泛的应用.在关系型数据结构理 论中,所有的数据都组织成一个个相互独立的二 ...

  5. Django框架之数据库ORM框架

    首先,我来介绍一下什么是ORM框架: O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思.在ORM框架中,它帮 ...

  6. 手撸ORM浅谈ORM框架之Query篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

  7. Mego(03) - ORM框架的新选择

    前言 从之前的两遍文章可以看出ORM的现状. Mego(01) - NET中主流ORM框架性能对比 Mego(02) - NET主流ORM框架分析 首先我们先谈下一个我们希望的ORM框架是什么样子的: ...

  8. 手撸ORM浅谈ORM框架之基础篇

    好奇害死猫 一直觉得ORM框架好用.功能强大集众多优点于一身,当然ORM并非完美无缺,任何事物优缺点并存!我曾一度认为以为使用了ORM框架根本不需要关注Sql语句如何执行的,更不用关心优化的问题!!! ...

  9. 手撸ORM浅谈ORM框架之Add篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

随机推荐

  1. cb15a_c++_vector容器的自增长_每次增加百分之50

    cb15a_c++_vector容器的自增长_每次增加百分之50每次自动容量代销扩充,增加百分之50_for windows C++,vector是用数组做出来的->数组的缺点和优点优点:具有下 ...

  2. JavaWeb网上图书商城完整项目--day02-5.ajax校验功能之服务器端三层实现

    regist.jsp页面中有异步请求服务器来对表单进行校验: l  校验登录名是否已注册过: l  校验Email是否已注册过: l  校验验证码是否正确. 这说明在UserServlet中需要提供相 ...

  3. 图灵学院-微服务11-分布式链路跟踪Sleuth详解

    当客户端访问到第一个service 1的时候,会生成当前链路追踪的一个全局的trance ID,在一次调用过Service1--Service2--Service3--Service4时,整个服务访问 ...

  4. Django的F查询和Q查询,事务,ORM执行原生SQL

    F查询和Q查询,事务及其他   F查询和Q查询 F查询 在上面所有的例子中,我们构造的过滤器都只是将字段值与某个我们自己设定的常量做比较.如果我们要对两个字段的值做比较,那该怎么做呢? Django ...

  5. NET 数据结构-单链表

    概念介绍: 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素. 链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置),元 ...

  6. ES6 promise用法总结

    一   什么时候promise? promise是异步编程的一个解决方案,是一个构造函数,身上带着all,resolve,reject,原型上有cath,then等方法 promise有两个特点: 1 ...

  7. Flask项目实战:创建电影网站-创世纪(1)

    以后要养成写博客的习惯,用来做笔记.本人看的东西很多很杂,但因为工作中很少涉及,造成看了之后就忘,或者看了就看了,但是没有融入的自己的知识体系里面. 写博客一方面是做记录,一方面是给这段时间业余学习的 ...

  8. VS2017 快捷键

    VS2017注释:先CTRL+K 然后CTRL+C   (ctrl按住不松,松开k按c) 取消注释:先CTRL+K,然后CTRL+U  (ctrl按住不松,松开k按c)

  9. 标记下 'net 查壳/脱壳/加壳' 工具

    net查壳工具 DotNet Id v1.0.0.3 该net程序集被“MaxToCode”加壳了(也不能完全相信). 加壳工具就是列表中列出的了. de4Net.exe脱壳工具版本de4dot-v3 ...

  10. 前端笔记(创建顺序数组、取选中月最后一天日期、判断变量、git命令)

    创建一个从0开始的顺序数组 [...new Array(5).keys()] //[0,1,2,3,4] 数组反向 [0,1,2,3,4,5].reverse() //[4,3,2,1,0] 取选中月 ...