我使用实体框架创建代码第一个模型并在安装第一个版本到客户端之后我们发现了数据库列的一些变化,我使用Entity Framework的迁移并且你应用迁移的所有步骤bat客户端的数据库不存在行上次更改的迁移历史记录,如果执行
则显示此消息Table 'nameTable' already exists
或
Additional information: Duplicate column name 'Reference'
这个类配置代码
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)
{
}
}
这个类首次迁移的代码
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");
}
}
答案 0 :(得分:1)
对于当前问题,看起来客户端迁移快照不同步。您可以在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以进行部署。