asp.net core系列 30 EF管理資料庫架構--必備知識 遷移

来源:https://www.cnblogs.com/MrHSR/archive/2019/02/22/10417484.html
-Advertisement-
Play Games

一.管理資料庫架構概述 EF Core 提供兩種主要方法來保持 EF Core 模型和資料庫架構同步。一是以 EF Core 模型為基準,二是以資料庫為基準。 (1)如果希望以 EF Core 模型為準,請使用遷移。 對 EF Core 模型進行更改時,此方法會以增量方式將相應架構更改應用到資料庫, ...


一.管理資料庫架構概述

         EF Core 提供兩種主要方法來保持 EF Core 模型和資料庫架構同步。一是以 EF Core 模型為基準,二是以資料庫為基準。

           (1)如果希望以 EF Core 模型為準,請使用遷移。 對 EF Core 模型進行更改時,此方法會以增量方式將相應架構更改應用到資料庫,以使資料庫保持與 EF Core 模型相容。

           (2)如果希望以資料庫架構為準,請使用反向工程。 使用此方法,可通過將資料庫架構反向工程到 EF Core 模型來生成相應的 DbContext 和實體類型。

  

  1.1. 遷移概述

    在開發期間,數據模型發生更改後,會與資料庫不同步。 雖然可以刪除該資料庫,讓 EF 創建一個新的資料庫來匹配該模型,但此過程會導致數據丟失。遷移作用是指:在 EF Core 中使用遷移功能,能夠以遞增方式更新資料庫架構,使其與應用程式的數據模型保持同步,同時保留資料庫中的現有數據。

      遷移包括 命令行工具和API,可協助執行以下任務:

             (1) 創建遷移。 生成資料庫更新的代碼腳本,用來準備將應用模型同步到資料庫。

             (2) 更新資料庫。通過“創建遷移”的代碼腳本,同步資料庫。

             (3) 自定義遷移代碼。有時需要修改或補充應用模型,並同步資料庫。

             (4) 刪除遷移。 刪除生成的遷移版本(該版本沒有更新到資料庫)。

             (5) 還原遷移。 撤消回滾資料庫更改(該版本已更新到資料庫)。

             (6) 生成 SQL腳本。 可能需要一個腳本來更新生產資料庫,或者對遷移代碼進行故障排除。

             (7) 在運行時應用遷移。 如果在設計期間更新和運行腳本不是最佳選項時,可在運行時調用 Migrate() 方法。

 

  2.1 安裝命令工具

    (1)對於Visual Studio開發,建議使用Package Manager Console(程式包管理器控制台)工具,使用windows上的PowerShell腳本。

              (2)對於其他開發環境,請選擇.NET Core CLI工具,使用dotnet命令是跨平臺的。

    本篇使用Visual Studio開發,使用Package Manager Console工具來進行遷移管理,用PowerShell腳本,並附帶上跨平臺管理 的dotnet命令。還是使用Blog和Post應用模型來演示。

 

 二. 命令演示

  2.1  創建遷移

    在定義初始化模型後,即應創建資料庫。 若要添加初始遷移,請運行以下命令,其中InitialCreate屬於自定義遷移類名,它繼承了DbContext。

PowerShell dotnet
Add-Migration InitialCreate dotnet ef migrations add InitialCreate

    關於準備工作和創建遷移註意事項這裡不在說明,請參考“asp.net core 系列 20 EF基於數據模型創建資料庫”。在開發中,一般都是使用多層架構,這裡新建了一個實體類庫EFGetStarted.AspNetCore.Model,在web項目的"依賴項"上右擊添加引用,選擇實體類庫。

    在實體類庫上安裝資料庫提供程式。創建三個類BloggingContext類(繼承DbContext)、Blog實體類、Post實體類。接著使用Package Manager Console工具運行Add-Migration InitialCreate命令。如下所圖所示:

    當運行了Add-Migration InitialCreate後,將在項目中生成一個Migrations 文件夾,併在其中生成三個文件,文件名中的時間戳有助於保證文件按時間順序排列:

      (1) 00000000000000_InitialCreate.cs--主遷移文件。 包含應用遷移所需的操作 Up() 和還原遷移所需的操作Down() 。

      (2) 00000000000000_InitialCreate.Designer.cs--遷移元數據文件。 包含 EF 所用的信息,如給實體類型構建屬性、主鍵、外鍵、索引、映射到數據表,主體和依賴關係等等,如下所示:

      (3) BloggingContextModelSnapshot.cs - 當前模型的快照。用於確定添加下一次遷移時更改的內容(用於遞增更新)。

 

  2.2 更新資料庫

    接下來,將遷移應用於資料庫以創建架構。命令如下:

PowerShell dotnet
Update-Database InitialCreate dotnet ef database update InitialCreate

    註意:更新到資料庫,需要創建資料庫的連接。項目中配置資料庫連接,一般是存放在web項目的appsettings.json文件中,併在Startup類中調用。這裡演示是直接寫死在Startup類代碼中,如下所示:

     var connection = "Data Source = {ip}; Initial Catalog = EFGetStarted.AspNetCore.NewDb; User ID = hsr;Password =js*2015;";
            services.AddDbContext<BloggingContext>
                (options => options.UseSqlServer(connection));

    在Package Manager Console工具中,運行Update-Database InitialCreate命令,同步到資料庫,如下所示:

 

  2.3 自定義遷移代碼

    更改 EF Core 模型後,資料庫架構可能不同步。為使其保持最新,請再添加一個新的遷移。例如我在Blog實體類,新添加了一個屬性,和修改了一個屬性的CLR類型。

    public class Blog
    {
        public int BlogId { get; set; }

        //將string 改為char
        public char Name { get; set; }
        //新增一個屬性
        public string Title { get; set; }

        public string Url { get; set; }
        public ICollection<Post> Posts { get; set; }
    }

    運行Add-Migration  Blog_Modifier,添加一個新的遷移

    再運行Update-Database Blog_Modifier,同步到資料庫中。char類型的Name生成後預設是nvarchar(1),對於指定屬性的長度,參考上篇關係資料庫建模。

    查看資料庫的遷移歷史,可以查看到遷移ID  MigrationId,其中20190222031152_Blog_Modifier 是最新的遷移同步到資料庫的版本。

     2.3.1 空遷移

      有時模型未變更,直接添加遷移也很有用處。 在這種情況下,添加新遷移會創建一個帶空類的代碼文件。可以自定義此遷移,執行與 EF Core 模型不直接相關的操作。 可能需要通過此方式管理的一些事項包括:

        (1)全文搜索

        (2)函數

        (3)存儲過程

        (4)觸發器

        (5)視圖

      通過上面操作,以Code First模式下,不需要對資料庫進行直接操作,在資料庫建模上,DBA以檢查資料庫架構為主。

   

   2.4 刪除遷移

     有時修,項目在添加遷移後,意識到需要在應用遷移前對 EF Core 模型作出其他更改。 要刪除上個遷移。 刪除遷移是使用了Add-Migration生成遷移後,還沒有應用Update-Database同步到資料庫架構。請使用如下命令。

PowerShell dotnet
Remove-Migration  Name dotnet ef migrations remove Name

 

   2.5 還原遷移

     如果已經對資料庫應用一個遷移(或多個遷移),但需將其複原(回滾),需要使用更新資料庫命令,並指定回滾時的目標遷移名稱。下麵還原到遷移名稱InitialCreate狀態時。運行PM> Update-Database InitialCreate後,資料庫同步,回到了最初InitialCreate遷移狀態,資料庫Blogs表還原到了當初。

 

  2.6 生成 SQL 腳本

     調試遷移或將其部署到生產資料庫時,生成一個 SQL 腳本很有幫助。 之後可進一步檢查該腳本的準確性並對其作出調整以滿足生產資料庫的需求 該腳本還可與部署技術結合使用。 基本命令如下。

PowerShell dotnet
Script-Migration dotnet ef migrations script

     Script-Migration參數介紹:

-From<String> 開始遷移。遷移可以通過名稱或ID來標識。數字0是一種特殊情況,這意味著在第一次遷移之前。預設值為0
-To<String> 結束遷移。預設值為最後一次遷移。
-Idempotent 生成可在任何遷移時在資料庫上使用的腳本。
-Output <String> 要將結果寫入的文件。如果省略該參數,則在創建應用程式運行時文件的文件夾中使用生成的名稱創建文件,例如:/obj/Debug/netcoreapp2.1/ghbkztfz.sql/

    下麵的示例使用InitialCreate遷移版本,創建一個sql腳本文件,輸出到D盤。

    PM> Script-Migration -From 0  -To InitialCreate -Output D:\InitialCreate.sql
IF OBJECT_ID(N'[__EFMigrationsHistory]') IS NULL
BEGIN
    CREATE TABLE [__EFMigrationsHistory] (
        [MigrationId] nvarchar(150) NOT NULL,
        [ProductVersion] nvarchar(32) NOT NULL,
        CONSTRAINT [PK___EFMigrationsHistory] PRIMARY KEY ([MigrationId])
    );
END;

GO

CREATE TABLE [Blogs] (
    [BlogId] int NOT NULL IDENTITY,
    [Name] nvarchar(max) NULL,
    [Url] nvarchar(max) NULL,
    CONSTRAINT [PK_Blogs] PRIMARY KEY ([BlogId])
);

GO

CREATE TABLE [Posts] (
    [PostId] int NOT NULL IDENTITY,
    [Title] nvarchar(max) NULL,
    [Content] nvarchar(max) NULL,
    [BlogId] int NOT NULL,
    CONSTRAINT [PK_Posts] PRIMARY KEY ([PostId]),
    CONSTRAINT [FK_Posts_Blogs_BlogId] FOREIGN KEY ([BlogId]) REFERENCES [Blogs] ([BlogId]) ON DELETE CASCADE
);

GO

CREATE INDEX [IX_Posts_BlogId] ON [Posts] ([BlogId]);

GO

INSERT INTO [__EFMigrationsHistory] ([MigrationId], [ProductVersion])
VALUES (N'20190222024519_InitialCreate', N'2.2.1-servicing-10028');

GO
View Code

    

  2.7 在運行時應用遷移

    某些應用程式可能希望在啟動或首次運行期間在運行時應用遷移。使用該Migrate()方法執行此操作。

    myDbContext.Database.Migrate();    

    註意:此方法並不適合所有場景。 儘管此方法非常適合具有本地資料庫的應用,但是大多數應用程式需要更可靠的部署策略,例如生成 SQL 腳本。

              請勿在 Migrate() 前調用 EnsureCreated()。 EnsureCreated() 會繞過遷移創建架構,這會導致 Migrate() 失敗。

 

 

   參考文獻:

    EF遷移

    Package Manager Console

 


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

-Advertisement-
Play Games
更多相關文章
  • package 向家康; import java.util.concurrent.ThreadLocalRandom; public class 練習21 { public static void main(String[] args) { // 隨機一個0--1之間的小數 double n=Mat ...
  • 原創文章,轉載請標註出處: "《Java基礎系列 二進位操作》" 概述 Java源碼中涉及到大量的二進位操作,非常的複雜,但非常的快速。 Java二進位表示法 首先瞭解下二進位,二進位是相對十進位而言的,當然還有八進位,十六進位等等,我們常用的都是十進位,電腦用的都是二進位,而符號表示常用十六進位 ...
  • 1. 查看Nginx的配置文件 命令 nginx -t ,如圖 2. 進入配置文件目錄 並查看目錄 cd /usr/loxa/nginx/conf , 可以看見有一個 nginx.conf文件 一個vhost 目錄 3. 我們先編輯 nginx.conf, 主要的這個 service 這是另一個配置 ...
  • 實常式序的界面效果如下圖所示: 在表單中的搜索條件有姓名,學號,成績。他們在一行中按照水平三等分排列。 在cshtml中用html實現上述表單效果的的代碼如下: 1 <form class="form-horizontal" role="form"> 2 <div class="row"> 3 <d ...
  • 寫程式的過程應該是一種藝術創作過程,我們寫出來的程式體現了我們的技術水平和個人修養, 也就是說作為程式員,自己寫的程式就是自己的臉面。讓自己有臉有面的第一步就是要遵循程 序編碼規範,這裡總結一些程式編寫規範。 1. 命名規範 表達清晰是命名規範的核心,常見的命名分格有: 1.1 Pascal風格 包 ...
  • //載入配置文件 var builder = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("appsettings.json", optional: false, relo ...
  • 這一篇繼續完善webnotebook,如果你讀過上一篇的內容,你應該知道怎麼去掛載webnotebook日誌和容器的遠程訪問,但是這些還遠不夠,webnotebook 總要和一些資料庫打交道吧,比如說mysql,mongodb,redis,通常情況下這些存儲設備要麼是以容器的方式承載,要麼是由DBA ...
  • ///這個是拿別人的,找到好多這個方法,溜了,不知道誰是原創 protected void btnPrint_Click(object sender, EventArgs e) { string url = "QR_CodePrintView.aspx?Code=" + tbAssetCode.Te ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...