当前位置:Gxlcms > 数据库问题 > EF架构~codeFirst从初始化到数据库迁移

EF架构~codeFirst从初始化到数据库迁移

时间:2021-07-01 10:21:17 帮助过:11人阅读

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            // 注意表单复数形式时,实体不能有下划线,必须是单词
       modelBuilder.Conventions.Remove<System.Data.Entity.ModelConfiguration.Conventions.PluralizingTableNameConvention>();
     }

技术分享

技术分享

其中__MigrationHistory表,它是数据变更的数据表,体现了数据库的历史

技术分享

(2)开始数据迁移

这时,我们看解决方案里,没有migrations文件夹,因为这时你没有开启变更计划

当开启变更后,才会出现这个文件夹

技术分享

 Enable-Migrations

然后在项目中就看到了migrations文件夹,它将存储我们数据库的变更记录

技术分享

 我们如果新添加了数据实体DO,或者修改了原来的实体,然后希望升级一个变更记录,可以使用add-migration 变更名(随便写)

技术分享

然后在我们项目的Migrations目录会多一个变更文件,它以时间戳开头,我们在变更执行时,这个时间戳是它顺序执行的关键

技术分享

(3)把模型的变更更新到数据库

同时,我们看一个数据表__MigrationHistory,它没有发生变化,这是因为我们没有把变更更新到数据库,如果希望更新到数据库,可以使用update-database来实现,如果不加版本号,默认更新的是最新的变更记录,它会包括之前的变更代码,在更新时它会与数据表__MigrationHistory里的变更记录进行对比,如果已经更新过了,就不会执行这个版本,而只会向后更新!

技术分享

执行完成后,我们再看一下数据表的变化,它也会多一条最新的变更记录,以后我们再有数据表变更,就使用这个方法即可,EF-migration只要我们好好用,它只会使我们的开发便得更快捷!

技术分享

(4)把模型的变更成SQL脚本,以便在生产环境中使用

Update-Database -Script -SourceMigration: $InitialDatabase -TargetMigration:init

上面代码执行后会生成一个SQL文件,我们拿这个文件可以到生产环境中去执行,就完成了数据库的更新!

 

文章转载至:http://www.cnblogs.com/lori/p/7065698.html

EF架构~codeFirst从初始化到数据库迁移

标签:解决方案   数据库版本   image   gif   注意   toolbar   ural   ons   tar   

人气教程排行