zoukankan      html  css  js  c++  java
  • EF基础知识小记七(拆分实体到多个表以及拆分表到多个实体)

    一、拆分实体到多个表

    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();

     二、拆分一张表到多个实体

    假设数据库中有一张表,里面包含一些常用的字段,但是也包含一些不常用的大字段。为了提供系统的性能,需要避免每个查询都去加载这些字段.这个时候我们就需要将表拆分成两个或者更多的实体.

  • 相关阅读:
    CF676E:The Last Fight Between Human and AI
    BZOJ2079: [Poi2010]Guilds
    BZOJ4518: [Sdoi2016]征途
    BZOJ2216: [Poi2011]Lightning Conductor
    51nod1766 树上的最远点对
    洛谷P1257 平面上的最接近点对
    BZOJ2144: 跳跳棋
    BZOJ4773: 负环
    BZOJ4552: [Tjoi2016&Heoi2016]排序
    The Falling Leaves(建树方法)
  • 原文地址:https://www.cnblogs.com/GreenLeaves/p/7652324.html
Copyright © 2011-2022 走看看