網(wǎng)站首頁 編程語言 正文
在上一篇文章中,簡單的介紹了使用Fluent API如何管理一對一的實(shí)體關(guān)系,在這篇文章中,接著介紹Fluent API如何管理一對多的實(shí)體關(guān)系。
要在數(shù)據(jù)庫中配置一對多關(guān)系,我們可以依賴EF約定,還可以使用數(shù)據(jù)注解或Fluent API來顯式創(chuàng)建關(guān)系。接下來使用捐贈者Donator和支付方法PayWay這兩個類來舉例子,這里的一對多關(guān)系是:一個人可以通過多種支付方式贊助我。
支付方式類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; } } }
因為一個贊助者可以通過多種支付方式贊助我,這句話就表明了Donator對象應(yīng)該有一個PayWay的集合,因此,我們要給Donator類新加入一個集合屬性,捐贈者類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è)置一對多 modelBuilder.Entity ().HasMany(p => p.PayWays).WithRequired(t => t.Donator); base.OnModelCreating(modelBuilder); } } }
控制臺程序定義如下:
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ù)庫結(jié)構(gòu)如下:
查詢數(shù)據(jù):
原文鏈接:https://www.cnblogs.com/dotnet261010/p/7995260.html
相關(guān)推薦
- 2022-05-05 輕量級ORM框架Dapper應(yīng)用之實(shí)現(xiàn)In操作_實(shí)用技巧
- 2022-03-18 Linux系統(tǒng)配置(服務(wù)控制)詳細(xì)介紹_Linux
- 2022-04-16 Python報錯:PermissionError:?[Errno?13]?Permission?de
- 2023-02-06 Go語言基礎(chǔ)學(xué)習(xí)之指針詳解_Golang
- 2022-04-25 Entity?Framework?Core生成列并跟蹤列記錄_實(shí)用技巧
- 2021-11-26 linux服務(wù)器磁盤空間擴(kuò)充方法_Linux
- 2022-04-18 Python腳本,標(biāo)識符,變量使用,腳本語句,注釋,模塊引用詳解_python
- 2024-04-07 mybatis-plus插入數(shù)據(jù)庫值無效(插入不對,沒有插入數(shù)據(jù)庫默認(rèn)值,int的類型的null會變
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- 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)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤: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)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支