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