Entity Framework Code First数据库迁移(DB Migration)

本文介绍如何使用Entity Framework进行手动及自动数据库迁移,并提供了解决自动迁移导致数据丢失的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、手动迁移

第1步、启用数据库迁移

 

打开程序包管理器控制台

工具->库程序包管理器->程序包管理器控制台

打开控制台后,在控制台管理窗口输入 Enable-Migrations 指令,铵下回车键,到这里已启用了数据库迁移,但还没执行,结果如下图:

第2步、运行数据库迁移

在控制台管理窗口输入 Add-Migration指令,来新增一条数据库迁移版本,输入时必须要带上一个版本名称 Add-Migration AddProductCategoryTypeName,如下图:

运行完成后会在解决方案里的Migrations文件夹中新增一个类,201407030630269_AddProductCategoryTypeName.cs

第3步、正式对数据库进行迁移动作,在控制器窗口里输入 Update-Database指令就可执行,如下图:

 

二、自动迁移

1、在Global.asax类里面的Application_Start()方法里加上一段代码

//TODO:启用自动数据库迁移
Database.SetInitializer(new MigrateDatabaseToLatestVersion<MyMvcShop.Models.MyMvcShopContext, Migrations.Configuration>()); 

2、在Migrations/Configuration.cs类里开启

AutomaticMigrationsEnabled = true;

3、每次有更新必须在窗口里执行一下数据库迁移指令 Update-Database

三、未应用自动迁移,因为自动迁移会导致数据丢失的解决办法

只要在控制台窗口里运行 Add-Migration Initial 指令再输入Update-Database执行一下更新就可以了。

 

转载于:https://www.cnblogs.com/mjhuangzk/p/3822410.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值