我使用Code First Migrations,自动模式。我只为一次需要直接SQL代码的迁移创建了Migrations文件夹,但是AutomaticMigrationsEnabled = true;
public Configuration()
{
AutomaticMigrationsEnabled = true;
AutomaticMigrationDataLossAllowed = true;
}
很多时候,我删除了数据库来重新创建它。看到调试器中的自动更新SQL代码,我意识到迁移系统有我的更改历史,事件我删除了源中的任何跟踪。
例如,我将MyTable1表名更改为MyTable2。然后我完全删除了数据库。当我执行“Update-Database -Script”时,我可以看到迁移仍然创建“MyTable1”然后重命名为“MyTable2”。
我完全糊涂了。我的代码中不存在“MyTable1”。它不在Migrations文件夹中,因为我使用自动迁移。它不在我的数据库的历史表中,因为我删除了它。我删除了bin和obj文件夹。那么,哪里存储了我的变化的历史?
答案 0 :(得分:1)
神秘解决了。我的迁移文件绑定了一个RESX文件。
此文件似乎将以前的数据库状态存储在"数据"元件。它被编纂成法典,因此我无法在我的文件中找到MyTable1文本。
<data name="Target" xml:space="preserve">
<value>H4sIAAAAAAAEAO1dW28cu5F+X2D/w0BPSXCikez12cSQE+jI0okSyxYs+WSRF6M1Q0kN93RPunt8LCz2l+3D/qT9C8u+81LFW7Mv4xUOcGANySJZLBaLxaqv//e//+fkz9820eIrSbMwid8cHB8eHSxIvErWYfzw5mCX3//+Dwd//tO//svJ+XrzbfFLU+9lUY+2jLM3B495vn29XGarR7IJssNNuEqTLLnPD1fJZhmsk+WLo6M/Lo+Pl4SSOKC0FouTj7s4