EF 關系規則(一對一、一對多、多對多...)


轉自:

http://www.cnblogs.com/dudu/archive/2011/07/11/ef_one-to-one_one-to-many_many-to-many.html

Entity Framework 實體關系總結:one-to-one, one-to-many, many-to-many

通過 Entiy Framework實踐系列 文章,理了理 Entity Framework 的實體關系。

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

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

1. 一對一關系(one-to-one)

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

類圖:

數據庫表結構:

Entity Framework中實體關系的定義:

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

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

類圖:

數據庫表結構:

Entity Framework中實體關系的定義:

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. 一對多關系(one-to-many,文章鏈接

類圖:

數據庫表結構:

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


3. 多對多關系(many-to-many,文章鏈接

類圖:

數據庫表結構:

Entity Framework中實體關系的定義:

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM