轉自:
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);
.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);
.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,文章鏈接)
類圖:
數據庫表結構:
modelBuilder.Entity<BlogSite>()
.HasMany(b => b.BlogPosts)
.WithRequired(p => p.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");
}
);
.HasMany(b => b.Categories)
.WithMany(c => c.BlogPosts)
.Map
(
m =>
{
m.MapLeftKey("BlogPostID");
m.MapRightKey("CategoryID");
m.ToTable("BlogPost_Category");
}
);