2011-06-16 59 views
4
重构数据库

我正在修改MVCMusicStore购物车。我希望使用EntityFramework重构数据库 - 而不是通过服务器浏览器。使用EntityFramework从代码

在我的模型文件夹中,我创建了一个新的FooEntities模型。

public class FooStoreEntities : DbContext 
{ 
    public DbSet<Foo> Foos { get; set; } 
    public DbSet<Category> Categories { get; set; } 
    public DbSet<FooMaker> FooMakers { get; set; } 
    public DbSet<Cart> Carts { get; set; } 
    public DbSet<Order> Orders { get; set; } 
    public DbSet<OrderDetail> OrderDetails { get; set; } 
} 

我也创造了额外的模型FooFooMakerCategory。其他模型已经存在于MVCMusicStore示例中。

我创建了一个SampleFooData类,该类继承自DropCreateDatabaseIfModelChanges<FooStoreEntities>并覆盖了seed方法以种子新表。

我在Global.asax.cs改变Application_Start方法包含System.Data.Entity.Database.SetInitializer(new FooStore.Models.SampleFooData());

web.config文件我有:

<connectionStrings> 
    <add name="FooStoreEntities" 
    connectionString="Data Source=|DataDirectory|FooStore.sdf" 
    providerName="System.Data.SqlServerCe.4.0"/> 
</connectionStrings> 

FooStore.sdf仍包含从MVCMusicStore应用程序的所有旧表。

当我执行web应用程序时,它遇到了SetInitializer断点,但似乎没有创建SampleFooData对象并在数据库中创建新表。我错过了什么?还是有一些基本的东西我不明白?

+0

[Entity Framework Database.SetInitializer简单地不工作...]的可能重复(http://stackoverflow.com/questions/6368553/entity-framework-database-setinitializer-simply-not-working) – 2011-06-16 12:46:09

回答