網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
Entity?Framework管理一對(duì)二實(shí)體關(guān)系_實(shí)用技巧
作者:.NET開(kāi)發(fā)菜鳥(niǎo) ? 更新時(shí)間: 2022-05-05 編程語(yǔ)言在上一篇文章中,簡(jiǎn)單的介紹了使用Fluent API如何管理一對(duì)一的實(shí)體關(guān)系,在這篇文章中,接著介紹Fluent API如何管理一對(duì)多的實(shí)體關(guān)系。
要在數(shù)據(jù)庫(kù)中配置一對(duì)多關(guān)系,我們可以依賴EF約定,還可以使用數(shù)據(jù)注解或Fluent API來(lái)顯式創(chuàng)建關(guān)系。接下來(lái)使用捐贈(zèng)者Donator和支付方法PayWay這兩個(gè)類來(lái)舉例子,這里的一對(duì)多關(guān)系是:一個(gè)人可以通過(guò)多種支付方式贊助我。
支付方式類PayWay結(jié)構(gòu)如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace OneToMany.Model.Model { public class PayWay { public int PayWayId { get; set; } public string Name { get; set; } public virtual Donator Donator { get; set; } } }
因?yàn)橐粋€(gè)贊助者可以通過(guò)多種支付方式贊助我,這句話就表明了Donator對(duì)象應(yīng)該有一個(gè)PayWay的集合,因此,我們要給Donator類新加入一個(gè)集合屬性,捐贈(zèng)者類Donator結(jié)構(gòu)如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace OneToMany.Model.Model { public class Donator { public int Id { get; set; } public string Name { get; set; } public string Amount { get; set; } public DateTime DonateDate { get; set; } ////// PayWay類型的集合屬性 /// public virtual ICollectionPayWays { get; set; } } }
Donator類的配置伙伴類的定義如下:
using OneToMany.Model.Model; using System; using System.Collections.Generic; using System.Data.Entity.ModelConfiguration; using System.Linq; using System.Text; using System.Threading.Tasks; namespace OneToMany.Map.Map { public class DonatorMap :EntityTypeConfiguration{ public DonatorMap() { ToTable("Donator"); //將Name設(shè)置為必須 this.Property(p => p.Name).IsRequired(); } } }
PayWay的配置伙伴類的定義如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using OneToMany.Model.Model; using System.Data.Entity.ModelConfiguration; namespace OneToMany.Map.Map { public class PayWayMap : EntityTypeConfiguration{ public PayWayMap() { ToTable("PayWay"); this.Property(p => p.Name).HasMaxLength(16); } } }
EFDbContext類定義如下:
using OneToMany.Model.Model; using System; using System.Collections.Generic; using System.Data.Entity; using System.Linq; using System.Text; using System.Threading.Tasks; namespace OneToMany.Map.EFContext { public class EFDbContext:DbContext { public EFDbContext() : base("name=CodeFirstApplication") { } public DbSetPayWays { get; set; } public DbSet Donators { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder) { // 設(shè)置主鍵 modelBuilder.Entity ().HasKey(p => p.PayWayId); modelBuilder.Entity ().HasKey(p => p.DonatorId); // 設(shè)置一對(duì)多 modelBuilder.Entity ().HasMany(p => p.PayWays).WithRequired(t => t.Donator); base.OnModelCreating(modelBuilder); } } }
控制臺(tái)程序定義如下:
using OneToMany.Map.EFContext; using OneToMany.Model.Model; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace OneToManyApplication { class Program { static void Main(string[] args) { using (var context = new EFDbContext()) { var donator = new Donator { Amount = 6, Name = "蝦米", DonateDate = DateTime.Now, PayWays = new List{ new PayWay{Name="支付寶"}, new PayWay{Name="微信"} } }; context.Donators.Add(donator); context.SaveChanges(); } Console.WriteLine("執(zhí)行成功"); Console.ReadKey(); } } }
程序運(yùn)行后數(shù)據(jù)庫(kù)結(jié)構(gòu)如下:
查詢數(shù)據(jù):
原文鏈接:https://www.cnblogs.com/dotnet261010/p/7995260.html
相關(guān)推薦
- 2022-10-04 python中xml格式的轉(zhuǎn)換方法_python
- 2024-04-06 elasticsearch(es)高級(jí)查詢api
- 2022-08-10 Golang泛型的使用方法詳解_Golang
- 2022-03-27 Android?Studio實(shí)現(xiàn)井字游戲_Android
- 2022-09-03 機(jī)器學(xué)習(xí)數(shù)據(jù)預(yù)處理之獨(dú)熱One-Hot編碼及其代碼詳解_python
- 2022-05-23 Python的代理類實(shí)現(xiàn),控制訪問(wèn)和修改屬性的權(quán)限你都了解嗎_python
- 2023-10-09 Cookie和localStorage存儲(chǔ)的區(qū)別
- 2022-11-16 通用?HTTP?簽名組件的另類實(shí)現(xiàn)方式_實(shí)用技巧
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支