MyException - 我的异常网
当前位置:我的异常网» 数据库 » asp.net mvc CodeFirst形式数据库迁移步骤

asp.net mvc CodeFirst形式数据库迁移步骤

www.MyException.Cn  网友分享于:2013-11-02  浏览:0次
asp.net mvc CodeFirst模式数据库迁移步骤

 

利用Code First模式构建好基本的类后,项目也开始搭建完毕并成功运行,而且已经将数据库表结构自动生成了。

但是,我有新的类要加入,有字段需要修改,那怎么办呢,删库,跑路 ?  哈哈 

 

利用数据库迁移,将原有结构不改动,将新建类进行单独建表操作,或者是已有数据库表,改变字段,那就修改表。

 

迁移步骤:

1.打开程序包管理器控制台:工具->NuGet包管理器->程序包管理器控制台.(当然还有其它方式也可以打开,我比较喜欢这种)

点击后将弹出程序包管理器控制台

 极其要注意的是默认项目!!!

2.启动数据库迁移,执行命令:enable-migrations

 

由于Models不一定就是直接利用项目中已有的文件夹Models,从而当你选中启动项目为asp.net mvc 框架类型时,此处将会报错

具体来看我当前项目的分布情况:

我将模型分离出来了,以至于当我默认选中SearchEngine为启动项目时,在程序包管理器控制台中输入的第一个命令就会报错

 

解决方案:选中默认项目,选择为DbContext所在的项目,此处我的是类库

成功操作会如下提示:

并且在DbContext同级目录下增加了migrations目录

 

3.开始数据库迁移命令

1.Add-migration [自定义版本名称]

  输入add-migration updateorderheader

2.update-database

  输入update-database

 

此处如果和我一样将DbContext单独分割出来的需要注意,需要在当前类库的配置文件中加上数据库的连接地址

 

如果是直接在asp.net mvc框架中的Models中加入的DbContext,则可不必,会直接读取Web.Config文件中的连接字符串

 

等待命令执行中......

出现异常了

 

 开始寻找我电脑中的SQL Server Configuration Manage ,如果有则打开,找到

 

 

 配置TCP/IP协议为已启用即可。

我的本地没有该工具,只能通过如下方式找到该处

点击我的电脑右键->管理->服务和应用程序->SQLServer配置管理器     ( 两次找这工具都没找到,貌似都是直接从这解决的)

 重新输入命令,等待执行

初步成功

 

由于数据库中有些表无需更改

我们可以在migrations目录中,更改需要增加或修改的具体表

 

 

通过修改其中的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文件,开启自动迁移

5.在项目Global.asax的Application_Start中加上如下代码行:

System.Data.Entity.Database.SetInitializer(new System.Data.Entity.MigrateDatabaseToLatestVersion<SAssassin.EF.Model.CodeFirst, SAssassin.EF.Model.Migrations.Configuration>());

 

 

到此,数据库迁移工作已经完毕了。

 

 2017-10-15,望技术有成后能回来看见自己的脚步。

 

文章评论

那些争议最大的编程观点
那些争议最大的编程观点
程序员都该阅读的书
程序员都该阅读的书
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
代码女神横空出世
代码女神横空出世
每天工作4小时的程序员
每天工作4小时的程序员
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
总结2014中国互联网十大段子
总结2014中国互联网十大段子
我是如何打败拖延症的
我是如何打败拖延症的
为什么程序员都是夜猫子
为什么程序员都是夜猫子
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
中美印日四国程序员比较
中美印日四国程序员比较
鲜为人知的编程真相
鲜为人知的编程真相
10个调试和排错的小建议
10个调试和排错的小建议
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
程序员必看的十大电影
程序员必看的十大电影
 程序员的样子
程序员的样子
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
漫画:程序员的工作
漫画:程序员的工作
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
我的丈夫是个程序员
我的丈夫是个程序员
如何成为一名黑客
如何成为一名黑客
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
老程序员的下场
老程序员的下场
旅行,写作,编程
旅行,写作,编程
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
程序员应该关注的一些事儿
程序员应该关注的一些事儿
程序员的鄙视链
程序员的鄙视链
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有