ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

最近打算用.NET Core写一份简单的后台系统,来练练手

然后又用到了Entity Framework Core 

发现园子里有些文章讲得不是那么细节,对于新手小白来说,可能会有点懵。

特意整理了几个细节.

正文

数据迁移

首先EF CORE跟以前的EF6是有不同点的,

微软官网列出的不同点:https://docs.microsoft.com/zh-cn/ef/efcore-and-ef6/features

安装 EF 核心 NuGet 包

若要使用 EF 核心,请为你想要使用的数据库提供程序安装 NuGet 包。 例如,如果目标 SQL Server,你将安装Microsoft.EntityFrameworkCore.SqlServer。

如果你打算使用迁移,则还应安装Microsoft.EntityFrameworkCore.Tools包。

Install-Package Microsoft.EntityFrameworkCore.SqlServer

Install-Package Microsoft.EntityFrameworkCore.Tools

注意:下面的讲解有一部分在前面的文章有出现过,为了照顾没有读前面文章的同学,代码就简单的贴出来。不多做讲解

首先新建一个 Model 类 SysUser:

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

 

 然后建立EFCoreContext类

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

自动创建数据库

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

此时我们的数据库 和数据都已经有了

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

数据迁移

此时重点来了,当我们已经有数据库表的时候,我们需要修改字段,如何进行迁移

首先打开VS->工具->NuGet包管理器->程序包管理控制台

输入命令:Add-Migration init(执行此命令项目生成一个目录(Migration))

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

 

我们会发现Model程序集下多了一个文件夹为Migrations里面有3个文件.如下:

 

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

 

xxxxxxx_init.cs主迁移文件。包含应用迁移(in Up())和恢复(in Down())所需的操作。

xxxxxxx_init.Designer.cs - 迁移元数据文件。包含EF使用的信息。

EFCoreContextModelSnapshot.cs - 当前模型的快照。主要用于确定添加下一次迁移时发生了哪些变化.

然后我们执行命令:

Update-Database

如果你的数据库没创建,是第一次,就会执行成功,

如果你前期创建过数据库.但是是第一次创建迁移..就会失败

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

 

果然报错了,提示我们的表结构已经存在了,

我们看看xxxxxx_init.cs文件:

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

可以看到,这里第一次生成的迁移方法是按照新增来迁移的..而不是修改。

我们把Up()   Down()里面的代码删掉

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移

 这样就相当于 本次的迁移,没有做任何操作。

 

 然后我们来创建真正的迁移版本:

 首先添加一个Email字段,然后把UserName的长度改为60

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zzyfyp.html