EF Code First 學習筆記,關於特性InverseProperty 使用遇到的一些問題

来源:http://www.cnblogs.com/prpr/archive/2016/01/12/5126017.html
-Advertisement-
Play Games

通過一些嘗試,終於把設置這種特性不生效的原因給理出來了,,本人Model 引用了一個基類層,基類層是基礎EF特性來做的,然而我更新了Model 的EF框架 層之後,導致兩個版本框架不一致,最終出現了我下麵說到的InverseProperty 不生效問題一個實體多個引用的情況我們來考慮一下下麵的情況:...


通過一些嘗試,終於把設置這種特性不生效的原因給理出來了,,本人Model 引用了一個基類層,基類層是基礎EF特性來做的,然而我更新了Model 的EF框架 層之後,導致兩個版本框架不一致,最終出現了我下麵說到的InverseProperty 不生效問題

 

一個實體多個引用的情況

我們來考慮一下下麵的情況:

 1 public class Lodging
 2     {
 3         public int LodgingId { get; set; }
 4         public string Name { get; set; }
 5         public string Owner { get; set; }
 6         public bool IsResort { get; set; }
 7         public decimal MilesFromNearestAirport { get; set; } 
 8         public Destination Target { get; set; }
 9         //第一聯繫人
10         public Person PrimaryContact { get; set; }
11         //第二聯繫人
12         public Person SecondaryContact { get; set; } 
13     } 
14 
15     public class Person
16     {
17         public int PersonID { get; set; }
18         public string FirstName { get; set; }
19         public string LastName { get; set; }
20         public List<Lodging> PrimaryContactFor { get; set; }
21         public List<Lodging> SecondaryContactFor { get; set; } 
22     }
View Code

Lodging(旅店)有兩個對Person表的引用,分別是PrimaryContact與SecondaryContact,同時,在Person表中也有對這兩個聯繫人的導航:PrimaryContactFor與SecondaryContactFor。

看看Code First預設會生成怎樣的資料庫

Lodging(旅店)有兩個對Person表的引用,分別是PrimaryContact與SecondaryContact,同時,在Person表中也有對這兩個聯繫人的導航:PrimaryContactFor與SecondaryContactFor。

看看Code First預設會生成怎樣的資料庫

天哪,竟然生成了四個外鍵。因為有兩套類型一樣的導航屬性與引用屬性,Code First無法確定它們之間的對應關係,就單獨為每個屬性都創建了一個關係。這肯定不是我們所期望的,為了讓Code First知道它們之間的對應關係,在這裡要用到逆導航屬性來解決。

使用Data Annotations:但是!!!!!,我用下麵的第一種方法,未成功,具體原因不明,希望有知道的可以給我一些指點,最終用的第二種方法來時間的關係

1        //第一聯繫人
2         [InverseProperty("PrimaryContactFor")] 
3         public Person PrimaryContact { get; set; }
4         //第二聯繫人
5         [InverseProperty("SecondaryContactFor")] 
6         public Person SecondaryContact { get; set; } 
View Code

或使用Fluent API:

1  modelBuilder.Entity<Lodging>().HasOptional(l => l.PrimaryContact).WithMany(p => p.PrimaryContactFor);
2  modelBuilder.Entity<Lodging>().HasOptional(l=>l.SecondaryContact).WithMany(p=>p.SecondaryContactFor);
View Code

 

再重新生成資料庫,結果如圖:


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

-Advertisement-
Play Games
更多相關文章
  • 本節講Asp.net 5的緩衝。解決方案可以通過網址:https://github.com/aspnet/Caching下載也是Asp.net 5開源代碼介紹的第6部分,前5部分鏈接如下: 1. DependencyInjection(依賴註入)項目代碼分析 2. Configuration 新.....
  • 數據結構,無外乎三:1. 一對一,線性表,數組是也;2. 一對多,樹,菜單是也;3. 多對多,圖,網路是也。涉及到樹,有一個平衡的問題,左旋轉,右旋轉,轉得人暈暈乎乎。好在陳廣的《數據結構C#描述》講解非常詳盡,值得一讀。對照該書的例子,採用反編譯的手段,寫了個小程式,主要的目的是為了學習方便,也便...
  • C#中的yield可以應用在一個可迭代的方法中,我們必須真正理解此關鍵詞,才能將它正確的應用到實際生產中。為了說明yield會出現讓我們迷惑的結果,下麵先定義一個MyObject類:1 class MyObject2 {3 public int Value{get;...
  • 作者:SmlAnt出處:http://www.cnblogs.com/smlAnt一、概述String是我們平常用得最多的基元類型之一,雖然我們經常使用而且感到非常熟悉;但很多朋友只知道一個字元串的定義、使用或知道如何使用StringBuilder來達到高效構建字元串,但是有多少朋友有興趣去瞭解背後...
  • 原文:http://www.cnblogs.com/cilence/archive/2012/05/28/2520712.htmlAsp.Net 請求處理機制前言我們都知道Web請求響應是基於Http協議,那麼我們可以這樣來理解,一次Web請求和響應的過程,實際上就是一次發送Http請求和接收Htt...
  • 做開發的都知道三元表達式,三元表達式的魅力是每個程式員都無法拒絕的,它能在一定程度上節約程式員的時間,也能讓代碼看起來不那麼臃腫。 三元表達式的語法很簡單:數據類型 變數名==XX ? PP : NN;是不是很簡單,能代替你寫一個簡單的if-else和一些switch了吧,當然一些複製的判斷還是得....
  • 事件處理實際上是一種具有特殊簽名的delegate, 像這個樣子:public delegate void EventHandler(object sender, EventArgs e);類型定義事件成員,就可以通知其他對象發生了特定的事情。如果定義一個事件成員,意味著類型要提供一下能力:#1,方...
  • 其實也沒什麼想繼續說重構了,你我都清楚這僅僅只是一個開始,進一步的就是靠個人去不斷積累重構經驗了。我們學到的依然只是套路,玩熟的話還遠著呢。不僅僅是何處重構,如何重構的問題,更需要對重構的時間進行掌控,並且迫切需要實施重構的勇氣。好吧,自學完了《重構》。用時18天。從來沒有如此興奮過,這一切好像都只...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...