日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

Entity Framework 实体关系总结:one-to-one, one-to-many, many-to-many

發(fā)布時間:2025/7/14 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Entity Framework 实体关系总结:one-to-one, one-to-many, many-to-many 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

通過 Entiy Framework實踐系列 文章,理了理 Entity Framework 的實體關(guān)系。

為什么要寫文章來理清這些關(guān)系?“血”的教訓(xùn)啊,剛開始使用 Entity Framework?的時候,由于沒有靜下心來認真理清關(guān)系,走了一些"痛不欲生"的彎路。而我們目前開發(fā)的項目都在使用 Entity Framework,為了避免其他人再經(jīng)歷"痛不欲生"的彎路。于是下定決心邊“理清關(guān)系”邊“寫博客”。而寫博客可以逼著自己把問題完整地解決,避免半途而廢。當(dāng)寫出這些文章,自己不知不覺對問題有了更深的理解。

溫故而知新,通過這篇總結(jié)將自己對EF實體關(guān)系的理解回鍋熱一熱,也許會有新的收獲;感情也一樣,當(dāng)感情冷下來的時候,別忘了回鍋熱一熱。

1. 一對一關(guān)系(one-to-one)

a) 單向一對一(文章鏈接)

類圖:

數(shù)據(jù)庫表結(jié)構(gòu):

Entity Framework中實體關(guān)系的定義:

modelBuilder.Entity<BlogSite>()
.HasRequired(b
=> b.BlogUser)
.WithMany()
.HasForeignKey(b
=> b.UserID);

b) 雙向一對一(文章鏈接)

類圖:

數(shù)據(jù)庫表結(jié)構(gòu):

Entity Framework中實體關(guān)系的定義:

modelBuilder.Entity<BlogSite>()
.HasRequired(b
=> b.BlogUser)
.WithMany()
.HasForeignKey(b
=> b.UserID);

modelBuilder.Entity
<BlogUser>()
.HasRequired(u
=> u.BlogSite)
.WithMany()
.HasForeignKey(u
=> u.BlogID);


2. 一對多關(guān)系(one-to-many,文章鏈接)

類圖:

數(shù)據(jù)庫表結(jié)構(gòu):

Entity Framework中實體關(guān)系的定義: modelBuilder.Entity<BlogSite>()
.HasMany(b
=> b.BlogPosts)
.WithRequired(p
=> p.BlogSite);


3. 多對多關(guān)系(many-to-many,文章鏈接)

類圖:

數(shù)據(jù)庫表結(jié)構(gòu):

Entity Framework中實體關(guān)系的定義:

modelBuilder.Entity<BlogPost>()
.HasMany(b
=> b.Categories)
.WithMany(c
=> c.BlogPosts)
.Map
(
m
=>
{
m.MapLeftKey(
"BlogPostID");
m.MapRightKey(
"CategoryID");
m.ToTable(
"BlogPost_Category");
}
);

總結(jié)

以上是生活随笔為你收集整理的Entity Framework 实体关系总结:one-to-one, one-to-many, many-to-many的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。