首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实体框架CTP4: SetInitializer放在哪里?

实体框架CTP4: SetInitializer放在哪里?
EN

Stack Overflow用户
提问于 2010-09-09 00:20:13
回答 4查看 13.2K关注 0票数 6

我正在尝试使用CTP4预览将实体框架(首先是代码)添加到一个使用测试数据运行的MVC应用程序中。

我目前正在收到以下错误:

支持'SchedulerContext‘上下文的模型在创建数据库后发生了变化。手动删除/更新数据库,或使用Database.SetInitializer实例调用IDatabaseInitializer。例如,RecreateDatabaseIfModelChanges策略将自动删除和重新创建数据库,并可选择使用新的数据为其种子。

我根本不想生成数据库,因为我已经有了一个数据库。因此,我尝试在SchedulerContext构造函数中添加以下内容:

代码语言:javascript
复制
Database.SetInitializer<SchedulerContext>(new CreateDatabaseOnlyIfNotExists<SchedulerContext>());

这一点都没有影响--下一次它运行时,我得到了同样的错误。这个错误似乎发生在它执行一个访问数据库的LINQ语句时--我认为这是第一个。

我应该把这句话写在哪里,还是说这句话根本就是解决这个问题的答案?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-09-09 04:14:10

更新

我只是简单地掩盖了这样一个事实:您已经有了一个数据库,并且不想创建另一个one...in --答案是将它放在您的SchedulerContext类中

代码语言:javascript
复制
protected override void OnModelCreating(System.Data.Entity.ModelConfiguration.ModelBuilder modelBuilder) {
    modelBuilder.IncludeMetadataInDatabase = false;
}

旧答案

你通常把它放在Global.asax里

代码语言:javascript
复制
protected void Application_Start() {
    Database.SetInitializer<SchedulerContext>(new CreateDatabaseOnlyIfNotExists<SchedulerContext>());
}

注意,只有在第一次使用数据上下文时才会初始化它。

更新

代码语言:javascript
复制
public class DataContextInitializer : CreateDatabaseOnlyIfNotExists<SchedulerContext> {
    protected override void Seed(SchedulerContext context) {
    }
}

然后像这样修改SetInitializer。

代码语言:javascript
复制
System.Data.Entity.Infrastructure.Database.SetInitializer<SchedulerContext>(new  DataContextInitializer());
票数 9
EN

Stack Overflow用户

发布于 2011-01-18 15:27:51

顺便说一句,从CTP5开始,这是在Global.asax中设置初始化器的正确方法。

protected void Application_Start() { System.Data.Entity.Database.DbDatabase.SetInitializer<NerdDinners>(new System.Data.Entity.Database.DropCreateDatabaseIfModelChanges<NerdDinners>()); }

票数 4
EN

Stack Overflow用户

发布于 2011-07-08 01:21:29

在EF 4.1中

代码语言:javascript
复制
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Conventions.Remove<IncludeMetadataConvention>();
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3672919

复制
相关文章

相似问题

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