接着上一篇Shadow Properties之美(一),我们来继续举一个有点啰嗦的栗子。
先看简单需求:某HR系统,需要记录员工资料。需要记录的资料有:

  • 员工号(规则:分公司所在城市拼音首字母,加上三位的顺序数字,例如 GZ001,CD001,SH007等;对于每个员工有且仅有一个员工号,且不会存在同一员工号属于不同员工的情况);
  • 姓;
  • 名;
  • 最后一次入职日期(有些员工可能会有来来回回超过一次的入职离职再入职,保存最后一次就好)
  • 其他。。。
    在继续讨论之前,会用到有关 逻辑设计 和 物理设计 的概念,它们两者的区别,建议可以先阅读一下 https://it.toolbox.com/blogs/timbryce/logical-vs-physical-design-do-you-know-the-difference-050306 ,然后我们再继续。
    针对这个需求,我们简单地会有以下这样逻辑设计的类:

    其中EmployeeCode就是 Unique Identifier (唯一标识符)
    (本篇的程序,可以在这里下载:https://github.com/kentliu2007/EFCoreDemo/tree/master/ShadowProperty 用的是VS 2017)
    并且习惯性地会有按照 Default大法,有以下的数据表以及程序:
  • 数据表:



    虽然default大法好,而且还可以借口 “用自增长ID来做主键,可以加快数据库做join的时候的速度”,所以才没有用 EmployeeCode来做主键(虽然这个才是Unique Identifier)。。。但是我们还是需要做一些不是完全default的改动,仔细看上面绿色标识的内容,请留意clustered index以及unique key。
  • 演示数据:
  • 然后我们还有比较传统的基于EF6的WebApi:








    图有点多,但是因为都按照 default 大法 来捣弄的。一切都很简单很溜,对吧?

不过等等,画风有点不对,负责BDD的同事(不论是SME/BA/QC)可能会跳起来,如果我们要查询员工号是 SH007 的员工,为什么是 http://localhost:62021/api/Employees/3 ?如果换个DB,手动操作一下,或者测试并发量大的前提下,说不定要 http://localhost:62021/api/Employees/250 才是 SH007的数据了。如果换成是用GUID来做ID字段的,就可能会有类似这样的:http://localhost:62021/api/Employees/85a13f20-2d3e-4a21-807d-c64f5a55a626 ,这个又是什么鬼?其他系统call这个api的时候,或者BDD的案例描述是:查询员工号是SH007的员工的资料。。。但是我怎么知道你这个DB里面,ID是什么数字(如果是GUID的话,鬼知道又是个什么冰糖葫芦串)?麻烦请说人话好不好?这种逻辑设计里面本来就没有的,由于物理设计才出现的东西,DataAccess层,请你自己留着和数据库两个慢慢玩,不要漏出来给其他层好不好?
还有,俩Employee的类,有点拖沓了吧?

好吧,为了保持跟逻辑层一致,并且不想要两个employee类,继续使用EF6,我们会有第二个版本:






这下画风正常了。不过一堆模块都需要引用或者基于 DataAccess 模块;还有虽然只有一个employee类了,但是还要加上一些其他internal的属性。。。总感觉还是做得不够优雅(混了牛奶和糖的美式啊)。

现在有了EF Core的Shadow Property,我们可以把这个做得很优雅(鼓掌)。Shadow Property就是让我们可以保持 逻辑设计层 美式的纯正,然后让 DataAccess层 可以处理和消化掉 物理设计层 特有的元素:






看,一切都很 “美式” 的优雅,不存在骗奶骗糖的感觉:从Component Diagram来看,各个模块都引用着正确的逻辑设计模块;DataAccess模块没有需要多产生一个拖沓的EF类;外部系统以及人机对话的时候,都是针对逻辑设计来交谈,且说的都是人话。

本篇图有点多,建议结合下载的源代码来阅读本文。

希望通过上述两个栗子,让大家能够感受到Shadow Property的美,且能在工作中更灵活地把它用起来。
谢谢能耐着性子看到这里的大神们。请温柔一点吐槽哈。

下一篇,我计划向大家介绍一下EF Core的一个“幕后英雄” -- Backing Fields。敬请期待噢。。。

Shadow Properties之美(二)【Microsoft Entity Framework Core随笔】的更多相关文章

  1. Shadow Properties之美(一)【Microsoft Entity Framework Core随笔】

    最近在做公司的项目的时候,开始把部分程序迁移到EF Core,然后有了一些感触,趁着还没忘却,还是先记录下来. EF Core还在成长中,我写这个的时候,版本是2.2.如果对着已有的EF 5/6来说, ...

  2. “幕后英雄”之Backing Fields【Microsoft Entity Framework Core随笔】

    刘德华 有一首歌叫<马桶>,其中有一句歌词是:每一个马桶都是英雄. EFCore也有一个英雄,在幕后默默地任劳任怨.它就叫 "支持字段" (Backing Fields ...

  3. Entity Framework Core 1.1 Preview 1 简介

    实体框架核心(EF Core)是Entity Framework的一个轻量级,可扩展和跨平台版本. 10月25日,Entity Framework Core 1.1 Preview 1发布了. 升级到 ...

  4. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 创建复杂数据模型

    Creating a complex data model 创建复杂数据模型 8 of 9 people found this helpful The Contoso University sampl ...

  5. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 排序、筛选、分页以及分组

    Sorting, filtering, paging, and grouping 7 of 8 people found this helpful By Tom Dykstra The Contoso ...

  6. Working with Data » 使用Visual Studio开发ASP.NET Core MVC and Entity Framework Core初学者教程

    原文地址:https://docs.asp.net/en/latest/data/ef-mvc/intro.html The Contoso University sample web applica ...

  7. Professional C# 6 and .NET Core 1.0 - 38 Entity Framework Core

    本文内容为转载,重新排版以供学习研究.如有侵权,请联系作者删除. 转载请注明本文出处:Professional C# 6 and .NET Core 1.0 - 38 Entity Framework ...

  8. Entity Framework Core 生成跟踪列

    本文翻译自<Entity Framework Core: Generate tracking columns>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意:我使用的是 ...

  9. Entity Framework Core 2.0 使用入门

    一.前言 Entity Framework(后面简称EF)作为微软家的ORM,自然而然从.NET Framework延续到了.NET Core.以前我也嫌弃EF太重而不去使用它,但是EF Core(E ...

随机推荐

  1. EmberJS 为什么我偏爱 Ember.js 胜过 Angular 和 React.js

    文章写的很老到,非常值得一看!评论也很精彩,值得一看 为什么我偏爱 Ember.js 胜过 Angular 和 React.js 前几天看到了这篇文章:Why I prefer Ember.js ov ...

  2. 关于matplotlib绘制直方图偏移的问题

    在使用pyplot绘制直方图的时候我发现了一个问题,在给函数.hist()传参的时候,如果传入的组数不是刚刚好(就是说这个组数如果是使用(最大值-最小值)/组距计算出来,而这个数字不是整除得来而是取整 ...

  3. react生命周期和组件生命周期

    React的组件在第一次挂在的时候首先获取父组件传递的props,接着获取初始的state值,接着经历挂载阶段的三个生命周期函数,也就是ComponentWillMount,render,Compon ...

  4. P2495 [SDOI2011]消耗战

    思路 虚树上DP 虚树相当于一颗包含了所有询问的关键点信息的树,包含的所有点只有询问点和它们的LCA,所以点数是\(2k\)级别的,这样的话复杂度就是\(O(\sum k)\),复杂度就对了 虚树重点 ...

  5. 20175312 2018-2019-2 《Java程序设计》第9周学习总结

    20175312 2018-2019-2 <Java程序设计>第9周学习总结 教材学习内容总结 已依照蓝墨云班课的要求完成了第九章的学习,主要的学习渠道是PPT,和书的课后习题. 总结如下 ...

  6. 关于查询ios的app更新的历史版本记录

    https://www.qimai.cn 推荐七麦数据 可以查询app的各种版本更新内容 由于历史久远忘记了自己app第一次上架的时间 通过这个可以查询

  7. Cannot resolve classpath entry: /Program Files/IBM/SQLLIB/java/db2java.zip

    在mybatis的逆向工程中,使用java代码和xml配置文件生成时出现以下的错误 原来自己在复制官方配置文件的参考时将这一句也复制了进来 删掉后运行即可!成功的话控制台是没有输出的

  8. 实验九 FBG 团队项目需求改进与系统设计

    任务一 A.<项目需求规格说明书>分析 根据老师的指导以及本周所学的OOA,分析改进上周编写的<项目需求规格说明书>,发现需求项目书UML图例描述不够完善,仅仅是用例图没办法更 ...

  9. Git的基本使用教程

    http://www.cnblogs.com/tugenhua0707/p/4050072.html 上传本地文件仓库到远程仓库大致步骤: 1.在安装完git时,先创建本地的一个仓库(新建一个文件夹) ...

  10. Failed to find configured root that contains

    这个主要问题是在android系统下7.0 拍照时,Android提供FileProvider类来供应用之间共享数据. 出现这个问题多为xml文件 path 类型和代码中调用的类型不同导致的 以下为多 ...