1. 程式人生 > >EF基礎知識小記七(拆分實體到多個表以及拆分表到多個實體)

EF基礎知識小記七(拆分實體到多個表以及拆分表到多個實體)

style 需要 性能 rri pub chang 常用 日常 ted

一、拆分實體到多個表

1、在日常開發中,會經常碰到一些老系統,當客戶提出一些新的需求,這些需求需要在原來的表的基礎上加一些字段,大多數人會選擇通過給原表添加字段的方式來完成這些需求,方法,雖然可行,但是如果架構不合理的系統,就會牽一發而動全身.所以處理這種需求比較合理的方式是:建一張新表來存放新的字段.

通過叫做合並兩張及以上的表到一個單獨的實體,也叫分拆一個實體到多個表,我們把每個組成部分當成一個邏輯實體.這個過程叫做邏輯分拆.

缺點:每當獲取實體時,框架都需要額外的Join聯結.

2、示例

下面通過一個示例簡單介紹下邏輯分拆

(1)、數據庫表設計圖

技術分享

(2)、編寫代碼

i、確認目標項目導入了EF的相關程序集

ii、創建Product實體,代碼如下:

    public class Product
    {
        [Key]
        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
        public int SKU { get; set; }

        public string Description { get; set; }
        public decimal Price { get; set; }
        public string ImgUrl { get; set; }
    }

iii、創建數據上下文對象,該對象必須繼承DbContext,代碼如下:

public class EF6RecipesContext:DbContext
    {
        public DbSet<Product> Products { get; set; }

        public EF6RecipesContext():base("name=EF6RecipeEntities")
        {
        }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            
base.OnModelCreating(modelBuilder); modelBuilder.Entity<Product>() .Map(m => { m.Properties(p => new { p.Sku, p.Description, p.Price }); m.ToTable("Product", "dbo"); }) .Map(m => { m.Properties(p => new { p.Sku, p.ImgUrl }); m.ToTable("ProductWebInfo", "dbo"); }); } }

iiii、編寫測試代碼:

            using (var context = new EF6RecipesContext())
            {
                var product = new Product
                {
                    Sku = 1,
                    Description = "啦啦啦",
                    Price = 1M,
                    ImgUrl = "1.jpg"
                };
                context.Products.Add(product);
                product = new Product
                {
                    Sku = 2,
                    Description = "哈哈哈",
                    Price = 2M,
                    ImgUrl = "2.jpg"
                };
                context.Products.Add(product);
                product = new Product
                {
                    Sku = 3,
                    Description = "呵呵呵",
                    Price = 3M,
                    ImgUrl = "3.jp"
                };
                context.Products.Add(product);
                context.SaveChanges();
            }
            using (var context = new EF6RecipesContext())
            {
                foreach (var p in context.Products)
                {
                    Console.WriteLine("{0} {1} {2} {3}", p.Sku, p.Description,p.Price.ToString("C"), p.ImgUrl);
                }
            }
            Console.ReadKey();

技術分享

技術分享

二、拆分一張表到多個實體

假設數據庫中有一張表,裏面包含一些常用的字段,但是也包含一些不常用的大字段。為了提供系統的性能,需要避免每個查詢都去加載這些字段.這個時候我們就需要將表拆分成兩個或者更多的實體.

EF基礎知識小記七(拆分實體到多個表以及拆分表到多個實體)