回到目錄html
在傳統的大型系統設計中,數據庫建模是個比開發更早的環節,先有數據庫,而後是ORM模型,最後纔是開發程序,而這種模型在EF出現後發生了轉變,並且有可能未來會被code first取代,由於你的關係型數據庫沒有必要定死,你在部署網站時,沒人願意先創建一大堆SQL語句,誰都願意在IIS上運行後,數據庫自動生成,不管是sqlserver,orcale,mysql它若是都是自動生成,那該多爽!事實上,這種開發模型已經愉愉的進入了咱們的世界裏,尤爲是在第三方服務器部署時,這種code first讓你感受更加方法,應該你不用在一個個創建數據表了,像香港雲這種第三方服務器,普通用戶不支持SQL命令,創建表只能一個一個的創建。mysql
而當你的數據庫被創建後,數據表的信息也能夠同時被初始化的,這也是今天要說的,它分於兩叔,第一在config裏開啓這個初始化功能,第二創建本身的Initializer類,讓它實現DropCreateDatabaseIfModelChanges<YourContext>泛型方法便可,具體看一下代碼web
一 配置啓用,將web.config裏的entityFramework改這樣sql
<entityFramework> <contexts> <context type="Lind.DDD.Manager.ManagerContext, Lind.DDD.Manager"> <databaseInitializer type="Lind.DDD.Manager.ManagerInitializer, Lind.DDD.Manager" /> </context> </contexts> <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework"> <parameters> <parameter value="v12.0" /> </parameters> </defaultConnectionFactory> </entityFramework>
二 編寫初始化類代碼數據庫
/// <summary> /// 數據庫初始化 /// </summary> public class ManagerInitializer : DropCreateDatabaseIfModelChanges<ManagerContext> { protected override void Seed(ManagerContext context) { try { #region 部門表 var department = new WebDepartments { About = "", DepartmentName = "公司", DeptLevel = 0, Operator = "admin", ParentID = null, SortNumber = 0, Status = 1, UpdateDate = DateTime.Now, }; context.WebDepartments.Add(department); context.SaveChanges(); #endregion #region 菜單表 var menu = new WebManageMenus { About = "", LinkUrl = "", MenuLevel = 1, MenuName = "根", Operator = "admin", ParentID = null, SortNumber = 0, Status = 1, UpdateDate = DateTime.Now, }; context.WebManageMenus.Add(menu); context.SaveChanges(); #endregion base.Seed(context); } catch (Exception) { throw; } } }
感謝各位的閱讀,但願本文章能夠幫到您!服務器
回到目錄ide