• EFCore的新东西


    我认真给.Neter们科普下EFCore的新东西,相信你也会爱上的。

    一 直面O/RM性能差

    说到O/RM,很多人会嗤之以鼻,性能差,这是真的吗?所谓ORM,其实就是用面向对象的思想来封装对数据库的访问操作,能以操作对象的方式来完成数据库的操作。开发者不用关心数据库,甚至可以完全不用写Sql,确实是件好事儿!那为啥会说性能差呢?

    成也萧何败也萧何,正是因为自动化了数据库操作,该过程是僵硬的,会导致在复杂的数据库环境下无法保障性能。但这怪O/RM框架吗?一方面O/RM设计的目标只是简化Sql,另一方面来说,使用O/RM性能差更多是使用的问题,而不是框架的问题。没有低性能的框架,只有不会用的开发者!当然,优秀的框架是能让开发者更简单更高效,EFCore里面,就有多个跟性能相关的新特性,一起来看看!

    二 EFCore前世今生

    2008年发布了EntityFramework第一个版本3.5,到2017年发布的6.2.0最新版本,累计发布了16个正式版本,常规O/RM框架能做的事儿,EF也已经做得非常优秀了。而EFCore则是站在巨人的肩膀上的,当下最新版本EFCore3.1还包含了多个前所未有的新特性,可谓是开发者福音!(为配合.Net5,EFCore下一个版本也叫EFCore5)

    (1)Sql索引支持

    数据查询时,通过控制linq语句顺序,可以做到走索引,现在EFCore在Code Fitst时,在ModelCreating里面可以直接配置非聚集索引了,主键还是默认聚集索引的。担心O/RM性能的小伙伴儿,有必要来好好看看。

    (2)数据库读写分离支持

    读写分离是中大型项目必备了,EFCore本身可以通过option来支持,轻松实现单Context连接多数据库,完成数据库读写分离支持。不过在实际开发中,我更愿意封装一层ContextFactory来管控,还能做到复杂均衡。

    (3)便携数据库迁移

    项目开发中,数据库结构的变更一般都是脚本支持,面对数据结构结构的的变更,数据的升级,只能编写复杂的Sql脚本;老师就有过惨痛的经历。而EFCore彻底解决了这个问题,每次数据库结构的变化,都可以保存一个数据库迁移文件,迁移文件轻松生成数据库。每个迁移文件对应数据;任何时期,都可以根据对应的迁移文件生成数据库。

    1 EFCore内置Api直接生成数据库,一次配置轻松生成
    2 EFTool工具迁移数据库,生成迁移文件再生成数据库
    3 dotNet命令迁移,生成迁移文件,生成数据库

    (4)内置数据转换器

    使用O/RM开发的小伙伴儿,基本上都离不开AutoMapper,因为总会有些数据在存储和程序中的类型不一致,现在EFCore中直接内置了数据转换器,还支持自定义模式,原生支持让性能更高使用更轻松!

    (5)各种数据库支持

    EFCore基本上已经覆盖了市面上全部的主流关系型数据库,甚至还支持了内存数据库。一招鲜可以吃遍天了,简直了~ 说到封装框架,我不是针对谁,微软独一档!下面是整理的详细清单:

    以上是EFCore中相对其他O/RM框架的一些新特性和优势,此外要在开发中应用好EFCore,还有蛮多需要学习的,比如数据初始化、Linq查询、复杂查询、延迟加载、惰性加载、级联删除、内置假删除,还有分布式环境下的数据一致性,分布式事务等等,都是不可或缺的。

  • 相关阅读:
    vue 调试工具devtools
    卷积神经网络基础
    Java项目源码基于javaweb的学籍管理系统
    mysql8 docker部署命令
    七夕特别篇 | 浪漫的Bug
    如何做大你的软件研发团队?
    Nuscenes 数据集
    java多线程为什么每个线程都有一个单独的栈 ?
    Hadoop学习总结(搭建Hadoop集群的安装准备)
    Qt中文件夹的操作
  • 原文地址:https://blog.csdn.net/qdwyj/article/details/126955752