• EFCodeFirst Migrations数据库迁移


    EFCodeFirst Migrations数据库迁移

    数据库迁移

    1.生成数据库

    • 修改类文件PortalContext.cs的静态构造函数,取消当数据库模型发生改变时删除当前数据库重建新数据库的设置。
    1. static PortalContext() 

    2. Database.SetInitializer<PortalContext>(null); 

    • 添加Migrations文件夹,并生成类文件Configuration.cs。
    1. namespace Portal.Migrations 

    2. using System; 
    3. using System.Data.Entity; 
    4. using System.Data.Entity.Migrations; 
    5. using System.Linq; 
    6.  
    7. internal sealed class Configuration : DbMigrationsConfiguration<Portal.PortalContext

    8. public Configuration() 

    9. AutomaticMigrationsEnabled = true

    10.  
    11. protected override void Seed(Portal.PortalContext context) 

    12. // This method will be called after migrating to the latest version. 
    13.  
    14. // You can use the DbSet<T>.AddOrUpdate() helper extension method  
    15. // to avoid creating duplicate seed data. E.g. 
    16. // 
    17. // context.People.AddOrUpdate( 
    18. // p => p.FullName, 
    19. // new Person { FullName = "Andrew Peters" }, 
    20. // new Person { FullName = "Brice Lambson" }, 
    21. // new Person { FullName = "Rowan Miller" } 
    22. // ); 
    23. // 



    • 在程序包管理器控制台,执行语句:
    1. PM> Update-Database -Verbose 
    • 在数据库模型中添加City类,执行程序包管理器控制台语句,Migrations文件夹中新增类文件
    1. PM> Add-Migration AddCity 
    • 版本回溯,修改数据库中表City,删除其中字段ProvinceNo。在程序包管理器控制台中执行以下两条语句:
    1. PM> Update-Database -Verbose 
    2. //版本回溯 
    3. PM> Update-Database –TargetMigration:"201309201643300_AddCity.cs" 
    • 生成数据库版本之间的Sql脚本,只生成,不执行
    1. Update-Database -Script -SourceMigration:"201309201643300_AddCity.cs" -TargetMigration:"201309201708043_ModifyCity.cs"  

    2.EF Code First Migrations语句的其他参数

    为指定的DbContext启用数据库迁移

    1. PM> Enable-Migrations -ContextTypeName Portal.PortalContext 

    设置是否允许自动迁移

    1. Enable-Migrations 

    生成的Configuration.cs类文件的构造函数

    1. public Configuration() 

    2. AutomaticMigrationsEnabled = false

    Enable-Migrations指定项目名称

    1. PM> Enable-Migrations -StartUpProjectName Portal 

    如果在“Package Manager Console”中选择了默认项目可以不设置“-StartUpProjectName”参数;如果多次执行此命令可以添加-Force参数。

    查看所执行的Sql语句 -Verbose指令

    1. Update-Database -Verbose  
  • 相关阅读:
    SpringCloud
    Springboot笔记
    SpringMVC学习随笔
    Spring中事务的理解
    Spring中Aop的理解
    FLutter 各种项目的目录创建
    flutter 打包Android 创建签名证书
    flutter web网站 第一次访问首屏页 空白卡顿 再显示
    flutter--报错--Flutter 调试时卡在 Installing buildappoutputsapkapp.apk
    flutter 顶部状态栏 底部栏 显示和隐藏
  • 原文地址:https://www.cnblogs.com/mmry/p/7071115.html
Copyright © 2020-2023  润新知