首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >我应该在DropCreateDatabaseIfModelChanges或DbMigrationsConfiguration中种子DB吗?

我应该在DropCreateDatabaseIfModelChanges或DbMigrationsConfiguration中种子DB吗?
EN

Stack Overflow用户
提问于 2015-05-28 15:56:39
回答 1查看 680关注 0票数 2

我有一个工作代码优先实体模型,并有一个模型更改策略:

代码语言:javascript
运行
复制
public class MyModelChangePolicy : DropCreateDatabaseIfModelChanges<MyDBContext>
{
    protected override void Seed(MyDBContext context)
    {
        //Add the enumeration type values
        context.SyncEnums(false);
        base.Seed(context);
    }
}

SyncEnums是我创建的扩展方法,它将数据加载到几个枚举类型表中。

现在,我正在努力将代码优先迁移添加到我的项目中。我正在使用本指南在MSDN上完成。。Configuration.cs已添加到Migrations文件夹下。但是它也有一个Seed方法。下面是自动生成的代码:

代码语言:javascript
运行
复制
internal sealed class Configuration : DbMigrationsConfiguration<MyDBContext>
{
    public Configuration()
    {
        AutomaticMigrationsEnabled = false;
    }

    protected override void Seed(MyDBContext context)
    {
        //  This method will be called after migrating to the latest version.
    }
}

我刚开始编写代码,这是我创建的第一个迁移计划。我的问题是:这两种种子方法有什么区别?我该用哪一种?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-28 16:37:24

第一个方法将在迁移期间删除和重新创建数据库的情况下,并仅在此情况下为数据库添加种子。第二个选项将在每次运行迁移时为您的数据库添加种子,而不管数据库是否被删除和重新创建。就我个人而言,我将与环境无关的数据库“常量”放在Configuration.Seed中。再说一遍,我从不将数据库作为部署的一部分(甚至在开发环境中)重新创建数据库。我希望这能帮到你。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30511570

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档