项目中用到了EF Code First和迁移,但发现有些方面似懂非懂。比如:如何在迁移文件中控制迁移过程?如果在迁移文件中执行SQL语句?如何使用Update-Database的其它参数?数据库在生产环境的时候如何迁移?于是就有了下面的这些体验:
enable-migration
第一次生成数据库时使用。
→ enable-migration
→ 在类库下多了Migrations文件夹,包含Configuration.cs和每次的迁移记录文件
每次的迁移文件大致是:
迁移的配置文件大致是:
数据库初始化
Database.SetInitializer(new MigrateDatabaseToLastesVerstion
Add-Migration
每次迁移保存在本地。
配置文件大致如下:
→ 比如增加一个列
→ 运行: Add-Migration somename
→ 迁移文件大致是
Update-Database
更新数据库,执行没有被执行的迁移文件。
→ 执行:update-database -verbose
verbose表示显示更新明细,会显示执行了哪些迁移,执行了哪些SQL语句。
→ 其它参数
TargetMigration
Script & SourceMigration:创建SQL语句
Force:允许数据丢失
ProjectName:DbMigrationsConfiguraiton所在的类库
ConfigurationTypeName:DbMigrationsConfiguration的继承类
SartUpProjectName:连接字符串所在的类库
ConnectionString & ConnectionProviderName:明确连接字符串或provider
或者通过:get-help update-database -detailed, 了解更多。
回滚
Update-Database -TargetMigration:”SomeMigrationName” -verbose
在迁移文件中自定义一些迁移动作,控制迁移过程
所有的迁移文件继承自DbMigration这个类,该类提供了很多方法供我们控制迁移过程。
→ 比如让增加的类有一个默认值
执行SQL语句
比如,现有数据的某些列为NULL,如果想给这些行的该列附上值,该如何做呢?
→ 改变领域模型
→ 执行:Add-Migration somename
→ 在迁移文件中执行SQL语句
→ Update-Database -verbose
数据库的种子数据
对生产环境下的数据库作迁移
→ 执行:udb -script -verbose
→ 弹出一个可以编写sql语句的窗口,此时没有与数据库连接
alter table sometable add column nvarchar(max)
insert into _MigrationHistory(MigrationId,CreatedOn, Model, ProductVersion) values(…)
→ 执行:udb -verbose
此时与数据库连接,执行语句
→ 如果想从某个一个迁移开始
udb -sourcemigration:”somename” -script
→ 执行: udb -verbose
关闭种子数据
Database.SetIntializer
Original: https://www.cnblogs.com/darrenji/p/5285855.html
Author: Darren Ji
Title: Entity Framework Code First迁移基本面拾遗
原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/551539/
转载文章受原作者版权保护。转载请注明原作者出处!