Vous créez un initialisateur personnalisé, qui hérite de DropCreateDatabaseIfModelChanges
o DropCreateDatabaseAlways
interface. Comme :
public class EntitiesContextInitializer : DropCreateDatabaseIfModelChanges<-YourDbContext->
Et ensuite vous écrasez la méthode Seed comme :
protected override void Seed(YourDbContext context)
Un exemple complet pourrait ressembler à ceci :
public class EntitiesContextInitializer : DropCreateDatabaseIfModelChanges<EntitiesContext>
{
protected override void Seed(EntitiesContext context)
{
List<Role> roles = new List<Role>
{
new Role {Id=1, Title="Admin"},
new Role {Id=2, Title="ProjectManager"},
new Role {Id=3, Title="Developer"}
};
// add data into context and save to db
foreach (Role r in roles)
{
context.Roles.Add(r);
}
context.SaveChanges();
}
}
Edit : Après avoir configuré ceci, vous devez aussi configurer Initializer, comme Ladislav Mrnka l'a mentionné.
Database.SetInitializer(new EntitiesContextInitializer());
ie. : dans Global.asax :
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
RegisterGlobalFilters(GlobalFilters.Filters);
RegisterRoutes(RouteTable.Routes);
Database.SetInitializer(new EntitiesContextInitializer());
}
N'oubliez pas d'ajouter using System.Data.Entity;
.....