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

2023-05-16

前言

最近打算用.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:

 

 然后建立EFCoreContext类

自动创建数据库

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

数据迁移

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

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

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

 

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

 

 

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

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

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

然后我们执行命令:

Update-Database

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


  

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

 

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

我们看看xxxxxx_init.cs文件:

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

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

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

 

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

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

 

 然后我们开始迁移..

 Add-Migration  x2 (这里是迁移版本名称,可自定义,可以根据版本回滚)

 成功创建迁移文件之后,我们更新数据库.

Update-Database x2

 然后Email字段加上了,UserName长度也修改了,UserName的数据也还在。

 

 

删除迁移

 的时候我们刚刚创建了一个迁移,还没应用到数据库,就发现自己需要变更实体.那我们就可以删除这个没有应用的迁移版本.

 执行命令如下:

 Remove-Migration

 注意,这里是没有应用过的迁移,可以删除.如果应用过了.则会收到错误信息  

 

迁移回滚

有些时候,我们需要回滚到之前的一个迁移版本.,比如我们部署的时候,开发版本和稳定版本肯定不一样..

那么我们就会用到回滚命令.

执行如下: 

Update-Database  这里填写需要回滚的版本名称

我们执行  Update-Database init   

然后我们会发现, x2中的长度已经回到30了,Email字段也没有了....

生成迁移SQL

 有的时候,我们的生产数据库,是需要用脚本来创建库的.所以我们也可以直接通过实体来生成SQL脚本.命令如下:

 Script-Migration

 

举一反三:Script-Migration x2  这个脚本可以自定义需要迁移的版本号.文件名,需要生成迁移脚本的上下文

 

转载于:https://www.cnblogs.com/shumin/p/8877297.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ASP.NET CORE系列【六】Entity Framework Core 之数据迁移 的相关文章

  • 如何打开实际上已关闭的 Wifi 适配器的无线电?

    我在用着托管无线网络 http managedwifi codeplex com获取我的 Wifi 适配器的无线电状态 如果收音机实际上已关闭 如何将其打开 像这样的东西 WlanClient wlanClient new WlanClie
  • 从 Delphi 调用 C# dll

    我用单一方法编写了 Net 3 5 dll 由Delphi exe调用 不幸的是它不起作用 步骤 1 使用以下代码创建 C 3 5 dll public class MyDllClass public static int MyDllMet
  • 将数据集导出到一个 Excel 文件的多个 Excel 工作表中

    我需要在同一工作簿的两个 Excel 工作表中导出两个数据集的值 我的查询是这样的 数据集一 DataSet ds1 new DataSet SqlCommand commandOpen new SqlCommand storedproc1
  • 从同步上下文调用异步方法

    我在代码中通过 HTTP 调用服务 最终使用 HttpClient SendAsync 方法 然后从 WebAPI 控制器操作调用此代码 大多数情况下 它工作得很好 测试通过 但是当我在 IIS 上部署时 我遇到了死锁 因为异步方法调用的调
  • 如何使用 .NET 4 运行时运行 PowerShell?

    我正在更新管理一些 NET 程序集的 PowerShell 脚本 该脚本是为针对 NET 2 与 PowerShell 运行的框架版本相同 构建的程序集编写的 但现在需要使用 NET 4 程序集以及 NET 2 程序集 由于 NET 4 支
  • 自定义行为的配置错误

    我创建了一个与 WCF 服务一起使用的自定义行为 以将所有错误记录到应用程序日志中 我做了一个BehaviorExtensionElement对于行为 public ErrorLoggingBehaviorExtensionElement
  • C# 无法访问已释放的对象

    我正在制作一个服务器 客户端应用程序 我将服务器套接字设置为侦听 并设置 BeginAccept 方法 当我关闭服务器套接字 Socket Close 以关闭服务器时 BeginAccept 方法的异步回调方法抛出异常 我检查了异常 发现异
  • 如何在 C# / .NET 中创建内存泄漏[重复]

    这个问题在这里已经有答案了 可能的重复 托管代码中是否可能存在内存泄漏 特别是 C 3 0 https stackoverflow com questions 6436620 is it possible to have a memory
  • 类似于 .NET Framework 2.0 的 MEF(托管可扩展性框架)

    我在自己的项目中使用了 MEF 并且非常喜欢它 这很容易 在弄清楚我们的awkwardAPI模型 它刚刚工作了 现在我需要 NET Framework 2 0 类似的东西 有没有可以在 NET Framework 2 0 下工作的类似项目
  • 终结器线程的范围是什么 - 每个应用程序域或每个进程?

    根据我的所有阅读 应该有一个 GC 线程来调用所有终结器 现在的问题是这个 一个 线程的范围是什么 每个进程或每个应用程序域 因为域的整体目的是在一个进程空间中分离并创建 独立 的不同应用程序 I read here http dn cod
  • StringComparison.InvariantCultureIgnoreCase 去哪儿了?

    我正在将 C 代码移植到 Windows 应用商店应用程序 令我惊讶的是 以下代码不再起作用 someString Equals someOtherString StringComparison InvariantCultureIgnore
  • 正则表达式的命名空间不起作用

    我正在翻新一些曾经在 NET Framework 3 5 上运行的旧代码 使其能够使用 C 在 NET Framework 4 上运行 以下正则表达式过去在 3 5 版本中运行良好 但由于某些奇怪的原因不再运行 public static
  • 如何禁用 Alt + F4 关闭表单?

    What is the best way to disable Alt F4 in a c win form to prevent the user from closing the form 我使用表单作为弹出对话框来显示进度条 但我不希
  • 两个 RichTextBox 具有相同的滚动条

    是否有任何可用的第三方工具有两个富文本框 但两者只有一个共享滚动条 我需要用两种不同的语言实现一些文本 但两个文本框应该同时滚动 public enum ScrollBarType uint SbHorz 0 SbVert 1 SbCtl
  • 有条件地在 Visual Studio 中嵌入资源 (C#)

    有没有办法有条件地将资源嵌入到 NET 项目中 IE 如果我定义了 INCLUDETHIS 那么我想要将某个大文件嵌入到 dll 中 否则我不希望它嵌入 我知道我可以做两个项目来做到这一点 但我希望在一个项目中完成这一切 使用该文件的代码很
  • 生成逗号分隔值

    假设我有一个字符串集合 foo bar xyz 我想从列表中生成一个逗号分隔的值 如下所示 foo bar xyz 请注意末尾缺少 我知道有多种方法可以生成此内容 使用 for 循环和 string Format 或 StringBuild
  • 在 Web 浏览器中禁用 F5 [重复]

    这个问题在这里已经有答案了 可能的重复 禁用浏览器的后退按钮 https stackoverflow com questions 961188 disable browsers back button 如何禁用浏览器上的 F5 刷新 htt
  • MSChart 控件中的自定义 X/Y 网格线

    我有一个带有简单 2D 折线图的 C Windows 窗体 我想向其中添加自定义 X 或 Y 轴标记 并绘制自定义网格线 例如 以突出显示的颜色 虚线 我查看了 customLabels 属性 但这似乎覆盖了我仍然想显示的默认网格 这是为了
  • 使用 IdentityDbContext 和 Code First 自动迁移表位置和架构的实体框架?

    我正在尝试使用 IdentityDbContext 类设置自动迁移更新 并将更改传播到整个数据库的实际 DbContext 在进入代码之前 在使用自动迁移实现 IdentityDbContext 时 我收到此错误 影响迁移历史系统表位置的自
  • IDisposable 的显式实现

    虽然有很多关于IDisposable在 SO 上找到 我还没有找到答案 我通常遵循这样的做法 当我的一个班级拥有一个IDisposable对象然后它也实现IDisposable并打电话Dispose在拥有的对象上 然而最近我遇到了一个类 它

随机推荐