EF架構~CodeFirst模型下的數據初始化

回到目錄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

相關文章
相關標籤/搜索