原文連接:https://www.entityframeworktutorial.net/code-first/seed-database-in-code-first.aspxhtml
EF 6 Code-First系列文章目錄:數據庫
你能夠在數據庫初始化的過程當中,插入數據到數據庫。當你想要給你的應用程序設置一些測試數據或者一些基本數據,這是很重要的一個方法。app
爲了插入原始數據到數據庫,你須要建立一個自定義的數據庫初始化策略,而且重寫Seed方法。ide
下面的代碼,展現了當數據庫初始化的時候,向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); } }
而後,在上下文類中設置自定義的數據庫初始化策略類;ui
public class SchoolContext: DbContext { public SchoolContext(): base("SchoolDB") { Database.SetInitializer(new SchoolDBInitializer()); } public DbSet<Student> Students { get; set; } public DbSet<Standard> Standards { get; set; } }