一、拆分实体到多个表

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 = ,
Description = "啦啦啦",
Price = 1M,
ImgUrl = "1.jpg"
};
context.Products.Add(product);
product = new Product
{
Sku = ,
Description = "哈哈哈",
Price = 2M,
ImgUrl = "2.jpg"
};
context.Products.Add(product);
product = new Product
{
Sku = ,
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();

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

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

最新文章

  1. Kooboo CMS技术文档之二:Kooboo CMS的安装步骤
  2. java17
  3. 利用PBfunc在Powerbuilder中使用https获取微信的AccessToken
  4. 原来现在很多人都用SignalR来实现Chat Room
  5. kuangbin_UnionFind C (HDU 1213)
  6. ERP_基于Oracle ADF的定制化企业级IT系统解决方案
  7. 跨域的小小总结:js跨域及跨域的几种解决方法
  8. Delphi:窗体自适应屏幕分辨率(根据预设值的比例改变)
  9. i++,++i 作为参数
  10. Java 第十一周总结
  11. MPAndroidChart图形联动
  12. npm包--rimraf
  13. python学习第二讲,pythonIDE介绍以及配置使用
  14. mas录屏,带系统声音和麦克风声音
  15. font awesome 页面小图标
  16. 使用PHPExcel实现数据批量导入到数据库
  17. hive引入jar包--HIVE.AUX.JARS.PATH和hive.aux.jars.path
  18. 锁、volatile、CAS 比较
  19. hdu 6154 CaoHaha&#39;s staff
  20. 关于chrome下的bug

热门文章

  1. qmake -简介
  2. trcd_extract_EDCD_new
  3. verilog基础--altera培训
  4. cmd运行命令
  5. Oracle实例名,服务名等概念区别与联系
  6. AirplaceLogger源代码解析
  7. hdu 2153 仙人球的残影
  8. Corel Video Studio Pro X5
  9. C#基础复习(1) 之 Struct与Class的区别
  10. ASP.NET Core 2 学习笔记(三)中间件