源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

asp.net mvc CodeFirst模式数据库迁移步骤详解

  • 时间:2021-06-24 23:16 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:asp.net mvc CodeFirst模式数据库迁移步骤详解
利用Code First模式构建好基本的类后,项目也开始搭建完毕并成功运行,而且已经将数据库表结构自动生成了。 但是,我有新的类要加入,有字段需要修改,那怎么办呢,删库,跑路 ? 哈哈 利用数据库迁移,将原有结构不改动,将新建类进行单独建表操作,或者是已有数据库表,改变字段,那就修改表。 [b]迁移步骤:[/b] 1.打开程序包管理器控制台:工具->NuGet包管理器->程序包管理器控制台.(当然还有其它方式也可以打开,我比较喜欢这种) [img]http://files.jb51.net/file_images/article/201710/2017101610581224.png[/img] 点击后将弹出程序包管理器控制台 [img]http://files.jb51.net/file_images/article/201710/2017101610581225.png[/img] 极其要注意的是默认项目!!! 2.启动数据库迁移,执行命令:enable-migrations [img]http://files.jb51.net/file_images/article/201710/2017101610581226.png[/img] 由于Models不一定就是直接利用项目中已有的文件夹Models,从而当你选中启动项目为asp.net mvc 框架类型时,此处将会报错 具体来看我当前项目的分布情况: [img]http://files.jb51.net/file_images/article/201710/2017101610581227.png[/img] 我将模型分离出来了,以至于当我默认选中SearchEngine为启动项目时,在程序包管理器控制台中输入的第一个命令就会报错 [img]http://files.jb51.net/file_images/article/201710/2017101610581228.png[/img] 解决方案:选中默认项目,选择为DbContext所在的项目,此处我的是类库 成功操作会如下提示: [img]http://files.jb51.net/file_images/article/201710/2017101610581229.png[/img] 并且在DbContext同级目录下增加了migrations目录 [img]http://files.jb51.net/file_images/article/201710/2017101610581230.png[/img] 3.开始数据库迁移命令 1.Add-migration [自定义版本名称]   输入add-migrationupdateorderheader [img]http://files.jb51.net/file_images/article/201710/2017101610581231.png[/img] 2.update-database   输入update-database [img]http://files.jb51.net/file_images/article/201710/2017101610581232.png[/img] 此处如果和我一样将DbContext单独分割出来的需要注意,需要在当前类库的配置文件中加上数据库的连接地址 [img]http://files.jb51.net/file_images/article/201710/2017101610581233.png[/img] 如果是直接在asp.net mvc框架中的Models中加入的DbContext,则可不必,会直接读取Web.Config文件中的连接字符串 等待命令执行中...... 出现异常了 [img]http://files.jb51.net/file_images/article/201710/20171016110414332.jpg?201791611424[/img] 开始寻找我电脑中的SQL Server Configuration Manage ,如果有则打开,找到 [img]http://files.jb51.net/file_images/article/201710/2017101610581235.png[/img] 配置TCP/IP协议为已启用即可。 我的本地没有该工具,只能通过如下方式找到该处 点击我的电脑右键->管理->服务和应用程序->SQLServer配置管理器 ( 两次找这工具都没找到,貌似都是直接从这解决的) 重新输入命令,等待执行 [img]http://files.jb51.net/file_images/article/201710/2017101610581236.png[/img] 初步成功 由于数据库中有些表无需更改 我们可以在migrations目录中,更改需要增加或修改的具体表 [img]http://files.jb51.net/file_images/article/201710/2017101610581237.png[/img] 通过修改其中的CreateTable/DropTable,可以控制哪些表需要改动
namespace SAssassin.EF.Model.Migrations
{
  using System;
  using System.Data.Entity.Migrations;

  public partial class updateorderheader : DbMigration
  {
    public override void Up()
    {
      CreateTable(
        "dbo.MyFileInfoes",
        c => new
        {
          Id = c.Int(nullable: false, identity: true),
          FileName = c.String(),
          FileDescription = c.String(),
          FilePath = c.String(),
          FileType = c.Byte(nullable: false),
          FileSize = c.String(),
          FileStatus = c.Byte(nullable: false),
          IsPublic = c.Byte(nullable: false),
          UserId = c.String(),
          UserName = c.String(),
          CreateDate = c.DateTime(nullable: false),
          LastModityDate = c.DateTime(nullable: false),
        })
        .PrimaryKey(t => t.Id);
    }

    public override void Down()
    {
      DropTable("dbo.MyFileInfoes");
    }
  }
}
4.修改代码配置,实现之后的操作没那么麻烦 修改migrations目录中的Configuration.cs文件,开启自动迁移 [img]http://files.jb51.net/file_images/article/201710/2017101610581238.png[/img] 5.在项目Global.asax的Application_Start中加上如下代码行:
System.Data.Entity.Database.SetInitializer(new System.Data.Entity.MigrateDatabaseToLatestVersion<SAssassin.EF.Model.CodeFirst, SAssassin.EF.Model.Migrations.Configuration>());
到此,数据库迁移工作已经完毕了。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部