EF Core創建實體的Code First標準方法

来源:https://www.cnblogs.com/ZhouAlex/archive/2018/11/20/9992234.html
-Advertisement-
Play Games

針對關係型資料庫,實體之間的關係最常見的就是通過外鍵關聯的一對一、一對多和多對多的關係,新的EF Core通過註釋和Fluent API 能夠做到接近於資料庫通過DML創建模型的效果了。實際上,通過DML 最大的優勢在於,能夠定義所謂的Independent/Dependent Entity具體的那 ...


針對關係型資料庫,實體之間的關係最常見的就是通過外鍵關聯的一對一、一對多和多對多的關係,新的EF Core通過註釋和Fluent API 能夠做到接近於資料庫通過DML創建模型的效果了。實際上,通過DML 最大的優勢在於,能夠定義所謂的Independent/Dependent Entity具體的那個欄位作為關聯欄位,而EF更多通過一種約定去描述這種關聯關係,不過通過Fluent API 能夠收工定義的操作範圍更近廣了。

 下麵的這個表關係實際上描述了大部分關係型資料庫的關聯關係,能夠覆蓋大部分場景,通過這個例子去說明Code First 創建實體的標準方法。

Members 和Tasks 關係,Member是Independent Entity, Tasks是Dependent Entity,定義類如下:

namespace MemberTask.Models
{
    public partial class Members
    {
        [Key]
        public int? MemberId { get; set; }
        public string MemberName { get; set; }
        [InverseProperty("Members")]
        public List<Tasks> Tasks { get; set; }

    }
}
namespace MemberTask.Models
{
    public partial class Tasks
    {
        [Key]
        public int? TaskId { get; set; }
        public int TaskName { get; set; }
        public int MemberId { get; set; }
        [ForeignKey("MemberId")]
        public Members Members { get; set; }
        //part of many2many
        [InverseProperty("Task")]
        public List<TaskAndOaTasksR> TaskAndOaTasksRs { get; set; }
    }
}

 在這兩個實體的關係中:

先看Tasks類(紅色字體部分),通過註釋指明,MemberId 欄位作為外鍵,而Members引用導航屬性,作為外鍵所關聯依賴的對象。

Members類,Tasks 列表導航屬性就是被引用對象,而註釋表明Members 就是Tasks中的引用導航屬性Members。

另外3個實體店關係為,Tasks和OaTasks是業務實體,TaskAndOaTasksRs實際上作為一個中間表,提供一種多對多的關係,這種模式實際上是作為靈活的一種實體模式,雖然有一定的空間損耗,但是無論哪種關係,或者未來需要擴展成為多對多的關係可以隨時實施。

 

OaTasks:

namespace MemberTask.Models
{
    public partial class  OaTasks
    {
        [Key]
        public int? OaTaskId { get; set; }
        public string OaTaskName { get; set; }
        [InverseProperty("OaTask")]
        public List<TaskAndOaTasksR> TaskAndOaTasksRs { get; set; }

    }
}

 TasksAndOaTasksRs:

namespace MemberTask.Models
{
    public partial class TaskAndOaTasksR
    {
        public int? TaskId { get; set; }
        [ForeignKey("TaskId")]
        public Tasks Task { get; set; }
        [ForeignKey("OaTaskId")]
        public int? OaTaskId { get; set; }
        public OaTasks OaTask { get; set; }

    }
}

TasksAndOaTasksRs在實際上使用的時候,是不需要實現TaskId查詢關聯的多個OaTaskId的,僅僅查詢TaskId & OaTaskId  的一一對應關係,因此通過引用導航屬性引用Tasks 和OaTasks。相反,Tasks 和OaTasks都有需要進行一對多關聯查詢,因此採用了列表導航屬性。

 

模型建好後,根據實際情況配置DbContext,特別是針對外鍵關聯,根據實際情況定義好OnDelete方法。

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.Entity<Members>()
                .Property(b => b.MemberId).ValueGeneratedNever();
            modelBuilder.Entity<Tasks>()
                .Property(t => t.TaskId).ValueGeneratedNever();
            modelBuilder.Entity<OaTasks>()
                .Property(o => o.OaTaskId).ValueGeneratedNever();

            modelBuilder.Entity<Tasks>()
                .HasOne(m=>m.Members)
                .WithMany(t=>t.Tasks)
                .OnDelete(DeleteBehavior.Cascade);

            // below is for many2many
            modelBuilder.Entity<TaskAndOaTasksR>()
                .HasOne(t => t.Task)
                .WithMany(tt => tt.TaskAndOaTasksRs);

            modelBuilder.Entity<TaskAndOaTasksR>()
                .HasOne(t => t.OaTask)
                .WithMany(tt => tt.TaskAndOaTasksRs);

            modelBuilder.Entity<TaskAndOaTasksR>()
                .HasKey(t => new {t.TaskId, t.OaTaskId});
            
        }

 運行資料庫更新命令,實體和資料庫模型就建好了。

 


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

-Advertisement-
Play Games
更多相關文章
  • 第一次寫博客,分享一個做的提取基因序列的程式,根據bed文件里的位置信息從基因組裡提取序列 源碼地址:https://github.com/Liuyuan2018/fastaTools/blob/master/pyGetFasta.py bed文件通常用來保存註釋基因信息,BED文件必須的3列: c ...
  • Python基礎知識(9):字元串格式化 字元串格式化有2種方法:一是用“%”,二是用format。 轉換標誌:,預設右對齊,%後面加上“-”表示左對齊;“+”表示在轉換值之前要加上正負號;“ ”(空白符)表示在正數前面保留空格;“0”表示轉換值若位數不夠用0填充。 最小欄位寬度(可選):轉換值轉換 ...
  • 編程語言介紹 Python介紹 Python安裝 第一個Python程式 變數 程式交互 格式化輸出 數據運算 數據類型 控制流程 進位與字元編碼 編程語言介紹 編程語言介紹 編程語言的定義及作用: 編程的定義:‘動詞’即寫代碼。 編程的作用:讓電腦以人類的思維執行某些事件。 編程語言的分類: 機 ...
  • ASP.NET -- WebForm: Session的使用 ...
  • 有道翻譯有官方介面,也有非官方介面。 有道官方介面 官方介面:https://openapi.youdao.com/openapi 可查詢英語單詞註釋、單詞發音、網路釋義(不一定存在),可獲取線上發音地址。 具體使用,可參考 C# 有道API翻譯 查詢單詞詳細信息 有道非官方介面 何謂非官方介面,即 ...
  • 從周一到周日的順序,獲取排序數值: int i = DateTime.Now.DayOfWeek - DayOfWeek.Monday; if (i == -1) i = 6; 獲取某日起,星期一日期: public static DateTime GetMondayDate(DateTime so ...
  • Stream s = Request.InputStream; int count = 0; byte[] buffer = new byte[1024]; StringBuilder reqXml = new StringBuilder(); while ((count = s.Read(buff ...
  • public SortedDictionary<string, string> GetRequestPost() { int i = 0; SortedDictionary<string, string> sArray = new SortedDictionary<string, string>() ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...