Asp.net MVC 中 CodeFirst 開發模式實例

来源:https://www.cnblogs.com/CherishTheYouth/archive/2018/11/06/CherishTheYouth_1106.html
-Advertisement-
Play Games

昨天寫的這篇博客因為下班時間到了忘記保存了,好鬱悶,得重新寫一遍。實習所在公司使用的是CodeFirst開發模式,最近開始參與到公司的項目裡面來了,發現這個模式特別好用,建庫建表改變欄位屬性添加刪除欄位等等操作都無需自己在資料庫動手操作,只需要編寫代碼即可實現,著實是方便了許多。今天來記錄一下如何使 ...


  昨天寫的這篇博客因為下班時間到了忘記保存了,好鬱悶,得重新寫一遍。實習所在公司使用的是CodeFirst開發模式,最近開始參與到公司的項目裡面來了,發現這個模式特別好用,建庫建表改變欄位屬性添加刪除欄位等等操作都無需自己在資料庫動手操作,只需要編寫代碼即可實現,著實是方便了許多。今天來記錄一下如何使用CodeFirst開發模式,閑言少敘,下麵進入正題。

(一)準備工作

  新建三個項目,其中一個為MVC項目(Console),另外兩個為類庫項目(Moel和ORM),三者用途如下:

Console:這個就不說了;

Model:這個項目里專門書寫數據實體類;

ORM:這個項目用來創建上下文,構建資料庫與實體類之間的映射關係;

如下圖所示:

(二)在Model中添加實體類User.cs

代碼如下:

namespace Model
{

    [Table("Sys_User")] //自動建表的表名
    public class User
    {
        /// <summary>
        /// 主鍵
        /// </summary>
        [Key]
        public Guid Id { get; set;}
        /// <summary>
        /// 登錄名
        /// </summary>
        [Required] //必填項(非空)
        [MaxLength(50)] //最大長度(50)
        public string LoginName { get; set;}

        /// <summary>
        /// 密碼
        /// </summary>
        [Required]
        [MaxLength(50)]
        public string Password { get; set; }

        /// <summary>
        /// 性別
        /// </summary>
        [Required]
        public bool Gender { set; get; }

        /// <summary>
        /// 是否啟用
        /// </summary>
        [Required]
        public bool IsEnable { get; set; }

        /// <summary>
        /// 真實姓名
        /// </summary>
        [MaxLength(50)]
        public string RealName { get; set; }

        [MaxLength(300)]
        public string Remark { get; set; }

        /// <summary>
        /// 創建時間
        /// </summary>
        public DateTime CreateTime { get; set; }

    }
}

 

(三)在ORM中書寫上下文,建立映射關係

1.在ORM中利用Nuget工具添加EF包:

2.新建類文件,添加如下代碼:

namespace ORM
{
    public class MyDbContext : DbContext
    {
        public MyDbContext()
           : base(GetConnectionString()) { }

        private static string GetConnectionString()
        {
            return "SqlServerConnectionString";
        }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
        }

        public DbSet<User> Users { get; set; }//建立實體類與表的映射關係
    }
}

 

上面的構造函數public MyDbContext():base("XXX"){},這個xxx位置填寫的是你在配置文件里配置資料庫鏈接的鏈接名,上面代碼我寫的是  SqlServerConnectionString。

(四)在配置文件中配置資料庫連接字元串 SqlServerConnectionString

  首先,同樣要用nuget工具將EF添加到 Console中,然後,在代碼中如下位置添加連接字元串:

需要註意的是:

<connectionStrings> 加到<configSections></configSections>的後面,不要加到前面去了,否則可能會出問題哦!

 代碼如下:

  <connectionStrings>
    <add name="SqlServerConnectString" providerName="System.Data.SqlClient" connectionString="Server=localhost;Database=CodeFirstDb;Integrated Security=False;User ID=sa;Password=168168;" /
  </connectionStrings>

 

 連接字元串里的內容就不多說了,這裡的資料庫也會自動生成,不用自己手動去建庫。

配置完ConnectionString後,記得要把System.Configuration這個引用添加到ORM項目中。

(五)數據遷移Migration (將Model的修改應用到資料庫中,且不會改變對應的表中的原始數據)

在ORM項目中,打開nuget管理工具的控制台模式

 

然後輸入指令:Enable-Migration:

 

 完成此步後,我們可以看到,ORM中多了一個文件夾,裡面有如下的內容:

下麵對Configuration.cs里的內容進行更改:

 

改動點見上圖。

(六)在Application_Start事件中初始化資料庫策略

  打開Console中的global.aspx文件,找到Application_Start事件,添加如下代碼:

 //當提供了初始化數據時,使用該形式,以初始化資料庫策略並填充一些數據(當某個Model改變了,就刪除原來的資料庫創建新的資料庫)
 Database.SetInitializer(new MigrateDatabaseToLatestVersion<MyDbContext,ORM.Migrations.Configuration>()); 

如下圖所示:

(七)在Console新建控制器,實現一個對User表的簡單應用

前面6步做好了,就基本大功告成了,下麵驗證一下,有沒有自動生成資料庫。

在控制器中添加控制器,直接選自動生成增刪改查功能的模板,如下所示:

這樣就自動生成了一些關於User的功能,我們打開這一頁面,可以看到:

這裡的一組數據是我加上去的,如果是首次運行,這裡沒有數據,只會顯示這一排欄位。

下麵看一下我的資料庫

這個資料庫已經生成了,要知道我之前是並沒有建這個庫和表的。

 下麵,我將User.cs中的Remark實體刪除,看看資料庫中有何變化:

然後再次運行程式:

結果是這樣的:

哦。。。。哦。。尷尬了啊,他禁止了我的數據遷移,說因為這會造成數據丟失,怎麼辦呢。好辦,只需要在ORM下的Configuration.cs中添加如下代碼即可解決:

 // 自動遷移時如果引起數據丟失是否可接受
  AutomaticMigrationDataLossAllowed = true;

 

看圖:

然後我再運行一下代碼:

再查看資料庫:

看資料庫,我們的Remark欄位已經不見了。

因為缺少這個欄位,所以在進行增刪改查功能是會出錯:

這是由於我們原來生成的View中有這個欄位,現在實體類里這個欄位刪除了,而view頁面中沒刪除造成的,只需要自己去把與Remark相關的欄位刪除就可以正常運行的。

下麵,我再把這個Remark欄位加上去,看看結果。

 

結果為:

看看資料庫:

關於其他的新建表,添加欄位等等功能,都是適用的,這裡我就再一 一演示了。

 

好了,這篇就寫到這裡了哦,希望能幫到你!加油!

大佬看到了 ,也希望指點一下,感激不盡!

 


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

-Advertisement-
Play Games
更多相關文章
  • 最近開發遇到一個項目,對方提供一個c#編寫的動態庫,圖片處理需要調用該動態庫方法,發現一張圖片處理起來需要5s時間,對方無法提供有效解決手段,抱著試一試的想法反編譯的對方的動態庫,發現其中問題。 一下分享c#兩個好用的反編譯工具 1.Reflector 2.ilspycn 個人更傾向用ilspycn ...
  • 自從大約一年前[發佈 .NET Standard 2.0 ](https://blogs.msdn.microsoft.com/dotnet/2017/08/14/announcing-net-standard-2-0/)以來,我們已經向 .NET Core 2.1 發佈了兩個更新,並即將發佈 .N... ...
  • 在前面隨筆《在Bootstrap開發框架中使用dataTable直接錄入表格行數據》中介紹了在Web頁面中使用Jquery DataTable插件進行對數據直接錄入操作,這種處理能夠給用戶提供較好的數據錄入體驗,本篇繼續上篇的內容,繼續介紹這個直接錄入的處理操作,主要涉及到控制項的初始化和數據源的綁定... ...
  • 概述 通過合併、拆分的功能,將不同的文檔中的幻燈片進行組合形成新的的文檔,同時也可以將一個多頁的PPT文檔按頁拆分成多個不同的文檔。此功能也豐富了編程人員對PPT幻燈片的操作的選擇。下麵將分別從以下幾個要點來分別闡述通過C#來合併、拆分PPT幻燈片的方法。 示例要點 1. 合併PPT幻燈片(2種方式 ...
  • 原因:Load窗體時,窗體未顯示 解決:1、Focus()之前添加this.Show(); 2、在Shown事件中添加Focus() ...
  • 最近一直在搗鼓.NET Core方面的東西,順便寫下點東西記錄下 1、打開vs2017,新建一個項目 2、vs會自動生成一個項目,然後打開NuGet搜索MySql.Data.EntityFrameworkCore下載 3、然後在Models下麵新建一個Student類,然後再新建一個類繼承DbCon ...
  • 基於工業4.0大背景下的工業物聯網是近幾年內熱門的話題,依靠信息化技術企業可以實現數字化轉型,生產可以實現智能化製造,設備可以實現自動化運作。然而,海量的數據採集是整個建設過程的基礎環節,如何處理與利用這海量的數據是信息化技術中最重要的開發工作。那麼,基於Azure國內雲端的Iot-Hub服務是提供... ...
  • 好久沒有寫Blog,都是因為不小心墜入了愛河,時間都給我家那位了,都沒時間加班了(嗨呀,不小心撒了一下狗糧),不過,還是希望單身的趕緊找到心儀的另一半,實在找不到,那就加班啊(開個玩笑,別認真)。 二維碼神器 現在出門在外,二維碼隨處可見,吃個東西、買個青菜,沒有weixin或者zhifubao的掃 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...