C# 重命名列,并首先通过EF代码中的迁移更改列类型

C# 重命名列,并首先通过EF代码中的迁移更改列类型,c#,asp.net-mvc,entity-framework,entity-framework-migrations,C#,Asp.net Mvc,Entity Framework,Entity Framework Migrations,我是Asp的新手。NETMVC5体系结构,也不太了解实体框架代码优先迁移。这是我通过迁移创建的表的快照,出于某些原因,我只想将ReleaseDate列重命名为ReleaseDate,还想将类型id的列类型从byte更改为int。是否可以通过迁移或任何其他替代方法执行此操作 迁移代码: namespace Vidly.Migrations { using System; using System.Data.Entity.Migrations;

我是Asp的新手。NETMVC5体系结构,也不太了解实体框架代码优先迁移。这是我通过迁移创建的表的快照,出于某些原因,我只想将ReleaseDate列重命名为ReleaseDate,还想将类型id的列类型从byte更改为int。是否可以通过迁移或任何其他替代方法执行此操作

迁移代码:

 namespace Vidly.Migrations
    {
        using System;
        using System.Data.Entity.Migrations;

        public partial class AddPropAndAnnotationsToMovie : DbMigration
        {
            public override void Up()
            {

                CreateTable(
                "dbo.Movies",
                c => new
                                    {
                    Id = c.Int(nullable: false, identity: true),
                    Name = c.String(nullable: false, maxLength: 255),
                    GenreId = c.Byte(nullable: false),
                    DateAdded = c.DateTime(nullable: false),
                    ReleaseDate = c.DateTime(nullable: false),
                    NumberInStock = c.Byte(nullable: false),
                        })
                    .PrimaryKey(t => t.Id)
                    .ForeignKey("dbo.Genres", t => t.GenreId, cascadeDelete: true)
                    .Index(t => t.GenreId);

                CreateTable(
                "dbo.Genres",
                c => new
                                    {
                    Id = c.Byte(nullable: false),
                    Name = c.String(nullable: false, maxLength: 255),
                        })
                    .PrimaryKey(t => t.Id);
            }

            public override void Down()
            {
                DropForeignKey("dbo.Movies", "GenreId", "dbo.Genres");
                DropIndex("dbo.Movies", new[] { "GenreId" });
                DropTable("dbo.Genres");
                DropTable("dbo.Movies");
            }
        }
    }

您可以反转迁移、编辑C#实体并创建新迁移。使用:

`Update-database -TargetMigration:0` 
要恢复所有迁移,或

`Update-database -TargetMigration:"name of migration file"`
恢复到特定的迁移删除不需要的迁移文件

然后在更改代码后运行
addmigration name
,以创建新的迁移文件

第三个选项是重命名代码中的字段,然后使用“添加迁移”

避免编辑迁移文件。更改代码、运行迁移、更新数据库


您应该发布代码,而不仅仅是图像。另外,请参阅如何创建一个最小的、完整的和可验证的示例。对不起,先生,我已经附加了代码。我已经尝试过了,但是由于我的迁移操作出错,剩下的唯一选项是重命名列和列类型。谢谢先生,这很有帮助。接受了,但先生,我在更改属性时遇到了另一个错误,因为实体也是外键,我不能在90分钟前发布新问题,不幸的是,我必须等待。好的,最好将此作为新问题发布。在发布下一个问题时添加注释。请务必发布错误消息和生成错误的代码。先生,我已经发布了问题,并尽我所能详细说明。帮助我学习你的知识。这是问题的链接,