1. 感慨一下
随着.net core的持续更新和升级,至少对于从事.net开发的人员和即将踏入这个领域的人来说,我相信大家的热情还是持续高涨的。国内的.net开发生态相比于之前来说,还是大有所好转的。在GitHub或者Gitee上使用.net core开发的开源项目也如雨后春笋一般,在不断增加,这当然少不了开源作者的付出和众多参与到开源项目的开发者的努力。
就拿ORM框架来说,国内也已经有了一些比较成熟的开源ORM项目,如sqlSugar,FreeSql等,这些框架对于一些主流数据库的支持也很完善了,特别对于国产的达梦和人大金仓数据库也有了很好的支持,这是一个很好的趋势,也都是值得被肯定和可持续发展的开源项目,如果对这两个项目还没有了解的同学,可以去GitHub上搜索了解和实践一下,说不定有一天就会用到你的项目当中来。
说到这里,也说一下微软一直以来也是有自己的ORM框架的。从.net framework时代的EntityFramework到现在的EntityFrameworkCore,微软也在持续更新,相信大家或多或少应该也有用过这个框架,有的人说这个框架很重,但我这里觉得未知全貌,不予评价。我自己也没有对这个框架了解和使用的特别深入,但是最近发现在使用EFCore的CodeFirst开发时,对于数据库的迁移,我认为它的支持还是做得很好的。为什么这么说呢,也是日常工作的一些有感而发。
现在项目的迭代开发过程中,一般都会分为开发,测试,生产环境。那么其中对于不同环境数据库的迁移(主要是表结构,数据),是迭代过程中不可缺少的一步。就我目前工作中的做法就是通过利用Navicat的数据库比对功能对不同环境下数据库比对生成差异化的sql脚本,最后放到测试环境,生产环境去执行。这样做,肯定是没有问题的,只要细心细致一点。然而EFCore给我们提供了一个更为快速和简单的方法。
2. 正文开始
2.1 创建一个项目
这里我以一个简单的控制台项目为例,我用到的开发工具是VS2022+.NET6,数据库用的是mysql,所以需要安装MySql的EFCore包,其它数据库版本可以参考下方的提供程序参考,引用自微软官方文档。使用VS2022创建一个项目,我给这个项目分了两层,一层作为我们的数据库实体层,另一层是应用层,我习惯用vs自带程序包管理控制台来安装,当然你也可以用Nuget包管理工具或者.NET CLI,由于主要是想演示EFCore的数据库迁移,所以还需要安装EFCore的命令行工具,安装代码都在下面了,安装完成后整个项目就是下面这个样子啦
Install-Package MySql.EntityFrameworkCore //MySql的EFCore 弃用,对最新版的EFCore没有支持
Install-Package Install-Package Po