Entity Framework Many to Many Relation Mapping(Entity Framework多對多關係映射)

来源:http://www.cnblogs.com/bestfriends/archive/2017/04/17/6721865.html
-Advertisement-
Play Games

通常我們在做資料庫設計時都會有兩張表是多對多關係的時候,在資料庫做多對多關係時候我們通常通過中間關聯表來處理,那我們現在在EF中是如何處理的呢? 假設我們有如下關係,用戶(User)包含多個角色(Role),角色包含多個用戶的情況下,我們如何用EF來處理這樣的資料庫設計呢? 接下來看如下代碼清單: ...


    通常我們在做資料庫設計時都會有兩張表是多對多關係的時候,在資料庫做多對多關係時候我們通常通過中間關聯表來處理,那我們現在在EF中是如何處理的呢?

    假設我們有如下關係,用戶(User)包含多個角色(Role),角色包含多個用戶的情況下,我們如何用EF來處理這樣的資料庫設計呢?

接下來看如下代碼清單:

首先看我們的UserRole實體

 1 public class User
 2 
 3 {
 4 
 5     public User() {}
 6 
 7  
 8 
 9     public int UserId { get; set; }
10 
11     public string Name { get; set; }
12 
13     public string Password { get; set; }
14 
15     public string PasswordSalt { get; set; }
16 
17     public Byte Status { get; set; }
18 
19     public DateTime CreatedDate { get; set; }
20 
21     public DateTime ModifiedDate { get; set; }
22 
23 }
24 
25 public class Role
26 
27 {
28 
29      public Role() {}
30 
31      public int RoleId { get; set; }
32 
33      public string RoleName { get; set; }
34 
35 }

接下來,我們知道用戶包含多個角色,那麼在User實體中添加這樣的代碼

public virtual ICollection<Role> Roles { get; set; }

 

User的構造函數中添加這樣代碼

this.Roles = new HashSet<Role>();

 

同樣的,角色也包含多個用戶,那麼在Role實體中添加這樣代碼

public virtual ICollection<User> Users { get; set; }

 

Role構造函數中添加這樣代碼

this.Users = new HashSet<User>();

 

接下來,構造我們繼承自DbContext類的DataContext

public class DataContext : DbContext

{

    public DataContext()

        : base("DataContext")

    {

    }

    public DbSet<User> Users { get; set; }

    public DbSet<Role> Roles { get; set; }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)

    {        

    }

}

 

接著,我們生成我們項目,就可以看到我們生成的資料庫關係了

可以看到我們中間的鏈接表生成的是User_UserIdRole_RoleId,但實際工作中我們可能不會這樣定義或者希望可以更多定製化,接下來我們通過Fluent API(註:我這裡直譯為流暢的API聲明,大家可以看字面意思理解,我不一定對)方式來進行數據聲明,我們這裡關係是一個用戶可以包含多個角色,一個角色也可以包含多個用戶,那我們在DataContextOnModelCreating重載方法里這樣寫:

modelBuilder.Entity<User>()

    .HasMany(r => r.Roles)

.WithMany(u => u.Users);

 

進一步我們指定中間鏈接表

 modelBuilder.Entity<User>()

     .HasMany(r => r.Roles)

     .WithMany(u => u.Users)

     .Map(ur =>

     {

         ur.MapLeftKey("UserId");

         ur.MapRightKey("RoleId");

         ur.ToTable("UserRoles");

     });

 

參考資料:

http://www.cnblogs.com/panchunting/p/entity-framework-code-first-fluent-api-configuring-relationships.html


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

-Advertisement-
Play Games
更多相關文章
  • 初學Xamarin ,各種折騰,大概這公司破電腦配置差,老是很多問題。 GitHub 真是個好東西,可以參考別人做的,不過下載來運行不了就各種折騰了,為此我重裝電腦兩次了,反正win10安裝就十幾分鐘的事。 問題一:沒有為此解決方案配置選中要生成的項目 這個問題的原因懶得找,可能是項目解決方案拷貝的 ...
  • (一)在運行期間處理和檢查代碼 自定義特性允許把自定義元數據與程式元素關聯起來。反射是一個普通術語,它描述了在運行過程中檢查和處理程式元素的功能。例如,反射允許完成的任務: 枚舉類型的成員 實例化新對象 執行對象的成員 查找程式集的信息 檢查應用於某種類型的自定義特性 創建和編譯新程式集 (二)自定 ...
  • EF中預設的decimal數據精度為兩位數,當我們資料庫設置的精度大於2時,EF將只會保留到2為精度。 網上找到常見的方法為重寫DbContext的OnModelCreating方法: 但如果數據表多或者Decimal類型欄位多的話,用OnModelCreating的方法將會變得相當冗餘,而且不便管 ...
  • url:是要傳輸的地址 type:傳輸類型POST表單,GET數據頭部 datatype:傳輸數據的類型 data:數據必須是一個“表示JSON對象的字元串”,而不是一個“JSON”對象 原因是jquery會把JSON對象序列化成標準POST的形式,你此處的{ id: id }會變成形好id=3這樣 ...
  • using System.IO; using System.Text; namespace iLIS.Common { /// /// 生成Excel文檔內容 /// 存入工作流 /// public class ExcelDocumentx { private readonly StreamWri... ...
  • 方法一: 1、首先建立一個按鈕,在後臺將調用或處理的內容寫入button_click中; 2、在前臺寫一個js函數,內容為document.getElementById("btn1").click() 或者document.getElementById("btn1").onclick() 3、在前臺 ...
  • 一.繼承的類型 在面向對象的編程中,有兩種截然不同繼承類型:實現繼承和介面繼承 1.實現繼承和介面繼承 *實現繼承:表示一個類型派生於基類型,它擁有該基類型的所有成員欄位和函數。在實現繼承中,派生類型採用基類型的每個函數的實現代碼,除非在派生類型的定義中指定某個函數的實現代碼。在需要給現有的類型添加 ...
  • 本次隨筆連載,主要用於記錄本人在項目中,用Xamarin.Forms開發APP中所使用的第三方技術或一些技巧。 準備: 1、VS2017(推薦)或VS2015; 2、JDK 1.8以上; 3、Xamarin.Forms 最新版; 4、Prism 擴展,打開VS的擴展和更新,在聯機中,搜索Prism, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...