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

来源:http://www.cnblogs.com/lori/archive/2016/03/02/5234709.html
-Advertisement-
Play Games

回到目錄 我為什麼會來 在傳統的大型系統設計中,資料庫建模是個比開發更早的環節,先有資料庫,然後是ORM模型,最後才是開發程式,而這種模型在EF出現後發生了轉變,而且有可能將來會被code first取代,因為你的關係型資料庫沒有必要定死,你在部署網站時,沒人願意先建立一大堆SQL語句,誰都願意在I


回到目錄

我為什麼會來

在傳統的大型系統設計中,資料庫建模是個比開發更早的環節,先有資料庫,然後是ORM模型,最後才是開發程式,而這種模型在EF出現後發生了轉變,而且有可能將來會被code first取代,因為你的關係型資料庫沒有必要定死,你在部署網站時,沒人願意先建立一大堆SQL語句,誰都願意在IIS上運行後,資料庫自動生成,無論是sqlserver,orcale,mysql它如果都是自動生成,那該多爽!事實上,這種開發模型已經愉愉的進入了我們的世界里,尤其是在第三方伺服器部署時,這種code first讓你感覺更加方法,應該你不用在一個個建立數據表了,像香港雲這種第三方伺服器,普通用戶不支持SQL命令,建立表只能一個一個的建立。

數據初始化

而當你的資料庫被建立後,數據表的信息也可以同時被初始化的,這也是今天要說的,它分於兩叔,第一在config里開啟這個初始化功能,第二建立自己的Initializer類,讓它實現DropCreateDatabaseIfModelChanges<YourContext>泛型方法即可,具體看一下代碼

一 配置啟用,將web.config里的entityFramework改這樣

<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;
            }


        }
    }

感謝各位的閱讀,希望本文章可以幫到您!

回到目錄


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 系統CentOS6.2 x86_64 1.yum安裝gcc,flex,m4,python/python-devel,ruby,libevent/libevent-devel,openssl/openssl-devel,bzip2/bzip2-devel,zlib/zlib-devel,bison,a
  • 簡介 VoIP(Voice over Internet Protocol)就是將模擬聲音訊號(Voice)數字化,以數據封包(Data Packet)的型式在 IP 數據網路 (IP Network)上做實時傳遞,最簡單的說法,就是通過網路來模擬我們平時的電話通話。 特點 VoIP最大的優勢是能廣泛
  • 當使用ClaimsIdentity的時候,Asp.Net MVC在生成AntiForgeryToken的時候會預設使用User.Identity中兩種ClaimsType的值:NameIdentifier (http://schemas.xmlsoap.org/ws/2005/05/identity...
  • 面對對象編程七大原則: 1. OCP 全稱:“Open-Closed Principle” 開放-封閉原則 說明:對擴展開放,對修改關閉。 優點:按照OCP原則設計出來的系統,降低了程式各部分之間的耦合性,其適應性、靈活性、穩定性都比較好。當已有軟體系統需要增加新的功能時,不需要對作為系統基礎的抽象
  • C#代碼中時間轉換為2016-01-24 12:12:12需要如下操作: DateTime.Parse(sj).ToString("yyyy-MM-dd HH:m:ss") 但是Oracle中SQL語句中時間轉換為此格式需如下操作: to_date(sj,'yyyy-mm-dd hh24:mi:ss
  • 1.單一職責原則 即:每一個類都只專註於做一件事情 2.里氏替換原則 在對軟體功能沒有影響的前提下 子類可以替換父類出現的位置,我們就稱之為里氏替換原則 3.依賴倒置原則 實現儘量依賴抽象 不依賴實現 4.介面隔離原則 應當為客戶端提供儘量小的單獨介面,而不是總的大的介面 5.迪米特法則 即知識最少
  • 1 // 註意:首先要在項目中添加引用 System.Management 2 3 using System; 4 using System.Collections.Generic; 5 using System.Linq; 6 using System.Web; 7 using System.Ma
  • yyyy-MM-dd HH:mm:ss 正則表達式如下: ^((((1[6-9]|[2-9]\d)\d{2})-(0?[13578]|1[02])-(0?[1-9]|[12]\d|3[01]))|(((1[6-9]|[2-9]\d)\d{2})-(0?[13456789]|1[012])-(0?[1
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...