EntityFramework Code First便捷工具——數據遷移

来源:http://www.cnblogs.com/NikoRanger/archive/2017/09/28/7605237.html
-Advertisement-
Play Games

使用EntityFramework Code First開發,數據遷移是一個不得不提的技術。 在我們的開發過程中,難免需要對模型進行改進,模型改進後,會導致實體集與資料庫不一致,當然我們可以通過刪除資料庫然後再重構資料庫,但是在生產環境中這樣做,這樣或多或少會出現一些問題。使用“數據遷移”,可以幫助 ...


使用EntityFramework Code First開發,數據遷移是一個不得不提的技術。

在我們的開發過程中,難免需要對模型進行改進,模型改進後,會導致實體集與資料庫不一致,當然我們可以通過刪除資料庫然後再重構資料庫,但是在生產環境中這樣做,這樣或多或少會出現一些問題。使用“數據遷移”,可以幫助我們解決這個問題。

數據遷移,添加的是我們對資料庫的改動,這一點可以從下麵Demo中可以看出來。每對資料庫進行一次改動(如刪除了某個表,更改了某一列),添加一次數據遷移,然後更新資料庫,這樣就能夠達到我們的目的。

先說一下我用的工具:

Vs2015 pro

Sql Serer 2014 developer

現在微軟的開發工具開發者版都免費了,個人用戶的話用起來還是會比較舒服的。

接下來放上一個小的Demo

新建一個空白解決方案(文件-新建-項目-其他項目類型-空白解決方案)Demo

然後添加兩個類庫,分別命名為Demo.Model和Demo.DAL。

添加一個Web應用程式(MVC),命名為Demo.UI

分別為Demo.Model、Demo.UI、Demo.DAL安裝EntitFramework。

程式包管理控制台輸入

Install-Package EntityFramwork

在Demo.Model中添加一個User類

namespace Demo.Model
{
    public class User
    {
        public int UserId { get; set; }

        public string UseraName { get; set; }

        public string Password{ get; set; }
    }
}

在Demo.DAL中添加一個DemoDbContext類,該類繼承自DbContext類,作用主要是對資料庫結構的映射(個人理解)。

using Demo.Model;
using System.Data.Entity;

namespace Demo.DAL
{
    public class DemoDbContext:DbContext
    {
        public DemoDbContext() : base("Name=DefaultConnection")
        {

        }
        //添加User表
        public IDbSet<User> Users { get; set; }
    }
}

開啟數據遷移

在程式包管理控制台輸入(不區分大小寫):

Enable-Migrations

執行完可以發現,這裡新建了一個名為 Migration 的文件夾和一個配置文件

然後進行下一步操作,設置 Demo.UI 為啟動項目

然後修改Web.config中的ConnectionString屬性

<connectionStrings>
<add name="DefaultConnection" connectionString="Data Source=.;User Id=sa;Password=123; Database=DemoDbContext" providerName="System.Data.SqlClient" />
</connectionStrings>

這裡定義的是連接字元串,不同的 Sql 版本對應的連接字元串可能會不一致,Sql Server Express 版本預設的實例名為 SQLEXPRESS 所以連接字元串應為

<connectionStrings>
<add name="DefaultConnection" connectionString="Data Source=./sqlexpress;User Id=sa;Password=123; Database=DemoDbContext" providerName="System.Data.SqlClient" />
</connectionStrings>

這裡註意一下 Database 屬性,這裡定義的為資料庫的名稱,這裡要與前面定義的 DemoDbContext 保持一致。

配置好以後,在程式包管理控制台視窗輸入

Add-Migration Add_User_Entity

這樣我們就添加了一次數據遷移,數據遷移的名稱為 Add_User_Entity

執行完之後會發現,Migration 文件夾添加了一個配置文件 201709250342176_Add_User_Entity.cs 前面是時間,後面是我們數據遷移的名字。

添加測試數據

Demo.DALMigration 文件夾中添加一個名為 Seed 的文件夾

添加一個 UserSeed

using Demo.Model;

namespace Demo.DAL.Migrations.Seed
{
    public class UserSeed
    {
        public readonly DemoDbContext _dbcontext;

        public UserSeed(DemoDbContext context)
        {
            _dbcontext = context;
        }

        public void Create()
        {
            AddSeed();
        }

        public void AddSeed()
        {
            User User = new User
            {
                Password = "123",
                UseraName = "Niko"
            };
            _dbcontext.Users.Add(User);
            _dbcontext.SaveChanges();
        }

     }
}

Migration 文件夾 Configuration.cs 中添加

    protected override void Seed(Demo.DAL.DemoDbContext context)
    {
        //添加種子數據
        new UserSeed(context).Create();

    }

添加完以後,執行最後一步 —— 更新資料庫

在程式包管理控制台輸入

Update-Database

或者

Update-Database -Verbose

後者會在控制台輸出對資料庫的操作過程,這樣我們在資料庫中就建立了一個名為 DemoDbContext 的資料庫,併在裡面添加了一個 Users 表,並添加了我們想要的測試數據:

以後每對資料庫進行一次改動,就添加一次數據遷移,然後更新資料庫,即可實現我們的目的。


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

-Advertisement-
Play Games
更多相關文章
  • 轉載需註明來源:http://www.cnblogs.com/yczcc/p/7594322.html openssl官網:https://www.openssl.org 下載源碼 源碼地址為:https://www.openssl.org/source/old/;當前最新版本為 1.1.0f,ht ...
  • 創建LVM分區: 相關命令: pvcreat /dev/sdb{1,2,3} 創建物理捲 vgcreat test_vg1 /dev/sdb1 創建捲組 vgcreat test_vg2 -s 16M /dev/sdb2 /dev/sdb3 指定PE大小為16M lvcreat 在已存在的捲組中創建 ...
  • 自己挖了一個大坑,,,然後苦逼的在碼代碼重寫樣式! 廢物不多少 直接上代碼 先在前臺創建一個TextBox,然後各種附加的屬性加上去:如圖所示 效果圖: 樣式代碼: 本文原創出處:http://www.cnblogs.com/PettyHandSome/ 歡迎各位轉載,但是未經作者本人同意,轉載文章 ...
  • 1. foreach C#編譯器會把foreach語句轉換為IEnumerable介面的方法和屬性。 foreach語句會解析為下麵的代碼段。 調用GetEnumerator()方法,獲得數組的一個枚舉 在while迴圈中,只要MoveNext()返回true,就一直迴圈下去 用Current屬性訪 ...
  • 用socket做了個程式,本地測試沒有問題,發佈到伺服器上時連接不上,用telnet測試連接失敗 伺服器上netstat -a 查看埠情況,127.0.0.1綁定埠9300處於監聽狀態,如下圖: 修改socket綁定IP為伺服器IP,埠狀態變為下圖: telnet連接測試成功! 很納悶,查了下 ...
  • 問題的產生的背景 由於我們使用了jenkins進行部署(jenkins~集群分發功能和職責處理),而對於.net core項目來說又是跨平臺的,所以對它的項目拉取,包的還原,項目的編譯和項目的發佈都是在一臺linux的jenkins節點上進行的,而我們開發時是在windows系統,所以在進行還原和編 ...
  • Tips 原文作者:Thomas Anderson, Blinkist 原文地址:Steve Jobs was successful because he mastered 'deep work' — here's how you can, too 你喝過麥卡倫姆威士忌嗎?如果你有這樣的經歷,你一定 ...
  • 出於安全考慮,在後臺與前臺進行數據傳輸時,往往不會直接傳輸實體模型,而是使用Dto(Data transfer object 數據傳輸對象),這樣在後臺往前臺傳遞數據時可以省略不必要的信息,只保留必要的信息,大大增強數據安全性。 下麵給出兩個相互對應的關係模型User、UserDto public ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...