Entity Framework MySql 数据库中的代码首次迁移

Entity Framework Code First Migration in MySql DataBase

我使用 entity framework 创建代码优先模型,在将第一个版本安装到客户端后,我们发现数据库的列发生了一些变化,我使用 Entity Framework 的迁移,你应用迁移的所有步骤客户端的数据库不存在上次更改的迁移历史行,如果执行

则显示此消息
Table 'nameTable' already exists

Additional information: Duplicate column name 'Reference'

此 class 配置代码

 internal sealed class Configuration : DbMigrationsConfiguration<GSM.DataAccess.GSMContext>
{
    public Configuration()
    {
        AutomaticMigrationsEnabled = true;
        AutomaticMigrationDataLossAllowed = false;
        SetSqlGenerator("MySql.Data.MySqlClient", new MySql.Data.Entity.MySqlMigrationSqlGenerator());  
    }

    protected override void Seed(GSM.DataAccess.GSMContext context)
    {

    }
}

和 class 第一次迁移的代码

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

            AddColumn("dbo.People", "Reference", c => c.String(unicode: false));
            AddColumn("dbo.Products", "Reference", c => c.String(unicode: false));
            AddColumn("dbo.Products", "SalePrice", c => c.String(unicode: false));
            AddColumn("dbo.Products", "WholePrice", c => c.String(unicode: false));


    }

    public override void Down()
    {

            DropColumn("dbo.People", "Address");
            DropColumn("dbo.People", "Reference");
            DropColumn("dbo.Products", "Reference");
            DropColumn("dbo.Products", "SalePrice");
            DropColumn("dbo.Products", "WholePrice");

    }
}

关于目前的问题,看起来是客户端迁移快照不同步。您可以只注释掉 Up() 方法中的冲突代码并执行更新数据库以使它们恢复同步。如果您担心缺少更改,则需要使用模式比较工具 (http://www.techbubbles.com/sql-server/schema-compare-for-sql-server-in-visual-studio-2013/)。

我会重新考虑您更新客户端 (PRODUCTION) 数据库的策略。我们所做的是从我们的迁移中生成一个脚本,该脚本位于客户端站点 运行 以更新它们。参见:http://cpratt.co/migrating-production-database-with-entity-framework-code-first/#at_pco=smlwn-1.0&at_si=54ad5c7b61c48943&at_ab=per-12&at_pos=0&at_tot=1

您还必须考虑您的数据库初始化程序是什么,并将其设置为 null 或 migratetolatestversion 以进行部署。