Entity Framework對同一張表配置一對多關係

来源:http://www.cnblogs.com/godbell/archive/2017/10/20/7702047.html
-Advertisement-
Play Games

在實際的項目開發中,可能會遇到同一張表同時保存自身和上級(或下級)的信息(一般是通過設置一個上級主鍵【ParentId】的列與主鍵【Id】關係) 例如:城市庫,有國家、省、市...,省的ParentId是國家的Id,同理市的ParentId是省的Id public class City { /// ...


在實際的項目開發中,可能會遇到同一張表同時保存自身和上級(或下級)的信息(一般是通過設置一個上級主鍵【ParentId】的列與主鍵【Id】關係)

例如:城市庫,有國家、省、市...,省的ParentId是國家的Id,同理市的ParentId是省的Id

public class City
    {
        /// <summary>
        /// Id
        /// </summary>
        public int Id { get; set; }
        /// <summary>
        /// 名稱
        /// </summary>
        public string Name { get; set; }
        /// <summary>
        /// 上級Id
        /// </summary>
        public int? ParentId { get; set; }
        /// <summary>
        /// 下級地區
        /// </summary>
        public virtual ICollection<City> ChildCitys { get; set; }
        /// <summary>
        /// 上級地區
        /// </summary>
        public virtual City Parent { get; set; }
    }
View Code
public class CityMap : EntityTypeConfiguration<City>
    {
        public CityMap()
        {
            ToTable("City");
            HasKey(c => c.Id);
            Property(c => c.Id).HasDatabaseGeneratedOption(System.ComponentModel.DataAnnotations.Schema.DatabaseGeneratedOption.Identity);
            Property(c => c.Name).HasMaxLength(50);

            //配置關係
            HasMany(c => c.ChildCitys).WithOptional(c => c.Parent).HasForeignKey(k => k.ParentId);
        }
    }
View Code
static void Main(string[] args)
        {

            var country = new City {  Name="中國" };
            var province = new City { Name = "廣東省" };
            var citys = new List<City>
            {
                new City { Name="廣州" },
                new City { Name="深圳" },
                new City { Name="珠海" }
            };
            province.ChildCitys = citys;
            country.ChildCitys = new List<City> { province };
            EFContext<City> context = new EFContext<City>();
            context.Table.Add(country);
            context.SaveChanges();
            Console.WriteLine("ok");
            Console.ReadKey();
        }
View Code

 運行控制台程式

然後查看資料庫:

 

 示例使用的是Entity Framework 6.X,同時上面的關係是0..1←→N,因為國家沒有上級(ParentId為null)


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

-Advertisement-
Play Games
更多相關文章
  • 服務端埠號變化了,如何基於秘鑰分發連接;如何實現自動創建秘鑰對,同時分發公鑰(編寫腳本實現) ...
  • linux是企業最常用的伺服器系統之一,CentOS是免費的,所以用的企業也挺多,今天給大家分享怎麼在自己電腦的虛擬機中安裝CentOS-6.5,以便用來玩耍,沒事的時候可以學學linux的一些知識。 1.下載CentOs安裝鏡像盤 下載地址:https://www.centos.org/downl ...
  • ********mysql******** 所需要的rpm文件: (https://downloads.mysql.com/archives/community) MySQL-client-5.5.48-1.linux2.6.x86_64.rpm MySQL-server-5.5.48-1.linu ...
  • 樹莓派Raspbian玩耍 安裝樹莓派並通過花生殼實現內網穿透 ...
  • #前提條件: 宿主機:windows7 虛擬機:REDHAT 開發環境 qt4.7.4 +vs2010 。 代碼在windows7 上編譯成功 ,運行正常 在linux下編譯需要的第三方庫已經編譯成功放在同一目錄,(其中建立不同版本的庫的軟鏈接) #目的:在linux上從新編譯。 #步驟:在虛擬機上 ...
  • 首先sudo su到root用戶 終端輸入 1. apt-get install mysql-server 2.apt-get isntall mysql-client 3.apt-get install libmysqlclient-dev 檢查MySQL狀態 netstat -tap | gre ...
  • 本文目錄: 1.1 URL重寫簡介1.2 if指令1.3 rewrite指令1.4 URL重寫和反向代理的區別 1.1 簡介 url重寫由ngx_http_rewrite_module模塊提供,預設會安裝,但該模塊功能的實現需要pcre。URL重寫技術不僅要求掌握幾個指令的語法、熟悉簡單的正則表達式 ...
  • 一、聲明: 本文采用操作系統版本: Centos 7 Linux系統 版本源:CentOS-7-x86_64-DVD-1708.iso 官網下載地址:http://isoredirect.centos.org/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1708 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...