原文鏈接:https://www.entityframeworktutorial.net/code-first/seed-database-in-code-first.aspx 你可以在資料庫初始化的過程中,插入數據到資料庫。當你想要給你的應用程式設置一些測試數據或者一些基本數據,這是很重要的一個方 ...
原文鏈接:https://www.entityframeworktutorial.net/code-first/seed-database-in-code-first.aspx
你可以在資料庫初始化的過程中,插入數據到資料庫。當你想要給你的應用程式設置一些測試數據或者一些基本數據,這是很重要的一個方法。
為了插入原始數據到資料庫,你需要創建一個自定義的資料庫初始化策略,並且重寫Seed方法。
下麵的代碼,展示了當資料庫初始化的時候,向Standard表插入一下預設的數據:
public class SchoolDBInitializer : DropCreateDatabaseAlways<SchoolDBContext>
{
protected override void Seed(SchoolDBContext context)
{
IList<Standard> defaultStandards = new List<Standard>();
defaultStandards.Add(new Standard() { StandardName = "Standard 1", Description = "First Standard" });
defaultStandards.Add(new Standard() { StandardName = "Standard 2", Description = "Second Standard" });
defaultStandards.Add(new Standard() { StandardName = "Standard 3", Description = "Third Standard" });
context.Standards.AddRange(defaultStandards);
base.Seed(context);
}
}
然後,在上下文類中設置自定義的資料庫初始化策略類;
public class SchoolContext: DbContext
{
public SchoolContext(): base("SchoolDB")
{
Database.SetInitializer(new SchoolDBInitializer());
}
public DbSet<Student> Students { get; set; }
public DbSet<Standard> Standards { get; set; }
}