Entity Framework 實體關系總結

作者: dudu  來源: 博客園  發布時間: 2011-10-28 20:43  閱讀: 17348 次  推薦: 12   原文鏈接   [收藏]  

  通過 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");
        }
    );
12
3
 
 
 

文章列表

arrow
arrow
    全站熱搜

    大師兄 發表在 痞客邦 留言(0) 人氣()