Entity Framework EF Migration 迁移

news/2024/7/7 20:42:36 标签: 数据库, oracle

针对Code First来说关注的只有实体类。当需求变更时只需要添加新的实体类或者在实体类中添加、删除、修改属性即可。但是修改完成之后要如何将修改同步到数据库中?

migration 机制就出现了

●启用Migrations
  ●通过Add-Migration添加Migration
  ●Update-Database更新数据库
  ●更新模型并添加新的Migration
  ●启动应用时自动将数据库更新至最新版本
  ●关于Automatic Migrations(自动迁移)

启用Migrations

enable-migrations
在这里插入图片描述
在这里插入图片描述

开启自动迁移。
在这里插入图片描述

通过Add-Migration添加Migration

如果已经存在数据库那么需要使用–IgnoreChanges参数来创建一个空的Migration来对应当前的数据库模型:
Add-Migration InitialCreate –IgnoreChanges

在这里插入图片描述
在这里插入图片描述

Update-Database更新数据库

在这里插入图片描述
这时数据库中多了一个名称为__MigrationsHistory表并有一条记录。

更新模型并添加新的Migration

在这里插入图片描述
1、在实体模型中添加属性 例如 xxx
2、add-migration addxxxColumn // addxxxColumn:名称最好与变更相关用于区分多个Migration便于维护:
3、Migrations文件夹中就多个类 addxxxColumn
4、update-database 命令将新的变更同步到数据库
注:使用参数-Verbose可以看到更多执行信息,包括执行的SQL语句。
在这里插入图片描述

启动应用时自动将数据库更新至最新

启动应用时将数据库更新至最新可以省略“update-database”命令执行这一过程,只需要添加了Migration,并且该Migration没有同步到数据库,那么在应用执行(实际上是DbContext在创建模型时OnModelCreating)将会把修改同步到数据库

在这里插入图片描述

》Database.SetInitializer(new MigrateDatabaseToLatestVersion<demoEF, Migrations.Configuration>());

只要运行程序, 就会自动updata-database啦

关于Automatic Migrations(自动迁移)

自动迁移指的是在执行“update-database”命令时,将对比实体模型与数据库结构,如果它们有差异则以实体模型为准,将差异同步到数据库。相当于省略了add-migration命令。

在这里插入图片描述
自动更新数据库(migrate database to latest version)与自动迁移(automatic migrations),
前者省略“update-database”后者省略“add-migration”,如果一起使用则两者都省略,
开发者仅需通过enable-migrations命令开启迁移,
然后在开发中修改完成实体类,就可以调试程序,调试程序过程中自动更新数据库结构。

回滚

在这里插入图片描述


http://www.niftyadmin.cn/n/5535301.html

相关文章

Nettyの网络聊天室扩展序列化算法

1、网络聊天室综合案例 客户端初始代码&#xff1a; Slf4j public class ChatClient {public static void main(String[] args) {NioEventLoopGroup group new NioEventLoopGroup();LoggingHandler LOGGING_HANDLER new LoggingHandler(LogLevel.DEBUG);MessageCodecSharabl…

C++中的类型转换操作符:static_cast reinterpret_cast const_cast dynamic_cast

目录​​​​​​​ C语言中的类型转换 C中的类型转换 C中的类型转换操作符 static_cast reinterpret_cast const_cast volatile关键字 赋值兼容 dynamic_cast C语言中的类型转换 基本概念&#xff1a;赋值运算符左右两侧类型不同&#xff0c;或形参与实参类型不匹配…

FastAPI-Cookie

fastapi-learning-notes/codes/ch01/main.py at master Relph1119/fastapi-learning-notes GitHub 1、Cookie的作用 Cookie可以充当用户认证的令牌&#xff0c;使得用户在首次登录后无需每次手动输入用户名和密码&#xff0c;即可访问受限资源&#xff0c;直到Cookie过期或…

设计模式-结构型-08-组合模式

文章目录 1、学校院系展示需求2、组合模式基本介绍3、组合模式示例3.1、 解决学校院系展示&#xff08;透明模式1&#xff09;3.2、高考的科目&#xff08;透明模式2&#xff09;3.3、高考的科目&#xff08;安全组合模式&#xff09; 4、JDK 源码分析5、注意事项和细节 1、学校…

BUG:AttributeError: module ‘websocket‘ has no attribute ‘enableTrace’

AttributeError: module ‘websocket’ has no attribute enableTrace’ 环境 windows 11 Python 3.10websocket 0.2.1 websocket-client 1.8.0 websockets 11.0.3 rel 0.4.9.19详情 一开始…

PromptCraft-Robotics部署步骤和问题记录

GitHub - microsoft/PromptCraft-Robotics: Community for applying LLMs to robotics and a robot simulator with ChatGPT integration 部署环境&#xff1a;UE4.27 Visual Studio 2022 Arisim1.8.1 可参考&#xff1a;git clone https://github.com/Microsoft/AirSim.gi…

保函到期提醒是银行或金融机构提供的一项服务,旨在确保客户及时了解保函即将到期的情况,从而避免因保函过期而导致的风险或违约责任。

保函到期提醒是银行或金融机构提供的一项服务&#xff0c;旨在确保客户及时了解保函即将到期的情况&#xff0c;从而避免因保函过期而导致的风险或违约责任。以下是保函到期提醒的一些关键方面&#xff1a; 1. **保函定义**&#xff1a; - 保函是一种由银行出具的书面承诺&…

CPU通过网络将IP camera的RTSP流(H.264编码或是H.265编码)拉回, 交给GPU解码并显示的处理流程

这个流程涉及到从IP摄像头获取视频流&#xff08;通过RTSP协议&#xff09;&#xff0c;然后将流传输给GPU进行解码和显示的过程。详细的流程描述如下&#xff1a; 1. 获取视频流: - **IP摄像头**: 摄像头通过RTSP&#xff08;Real-Time Streaming Protocol&#xff09;将…