1.4 Delving deep into object/relational differences 深入挖掘对象关系的不同

理解面向对象和关系世界的不同是重要的,因为他会影响你设计一个对象模型或者领域模型以及数据库。
这个不匹配被拆分成了几个部分:数据类型的不匹配,关联的不匹配,颗粒尺度的不匹配,继承的不配,识别的不匹配,在下面的几个部分,我们会轮流的探究他们,为了更好的阐述这个不匹配,我们还会使用前面提到的例子。

1.4.1 The datatype mismatch 数据类型的不匹配

数据类型的不匹配是指对象和关系使用的数据表现和约束是不同的,当你往数据库中的表添加一列的时候,你必须要给他制定一个类型,现代数据库支持char,varchar,int,decimal,data等等,当类面对这个的时候,情况变得不同,数据库的Int和bigint类型非常适合.net的Int32,Int54类型,但是其他的数据库类型在.net里面没有一个转却的匹配,你 可以在列上设置一个约束来强制业务规则,当我们的数据库是为好几个应用程序服务,并不是只有你更新数据的时候的时候,这是非常值得期待的事情,在.net里面,varchar是不存在的,最相近的类型是String,但是它不支持声明长度限制(它可以保存2G的数据),如果你想检查String的值不超过期望值,你不得不在set属性中实现这个坚持,或者是在发往数据库之前调用一个检查方法。
另一个关于数据类型不匹配的例子是二进制数据,每个数据库都接受二进制数据,但是含有二进制数据的列不知道这个数据代表的是什么,它可能是text或者PDF文件,图片等等,在.net中,你可以用一个对象来表示这个列,但它将是无意义的,因为如果你知道这列存储的是哪种数据,如果是文件你可以使用流对象,如果是图片Image是最好的选择。
最后一个关于类型的不同是当你使用date的时候,根据数据库供应商和版本,你可以有很多的数据库类型供使用去存储一个日期,举例子,在SQLServer2005之前(包括),你可以使用DateTime和SmallDateTime,SQLServer2008又引入了两个数据类型:Date,Time,如你所想,Date只包含日期,Time只包含时间,在.net中,你只有一个DateTime类去表示Date和Time,处理这个不匹配并不十分困难,但是反过来,but it requires a bit of discipline when instantiating the object
from database data and vice versa.

正如你看到的,数据类型的不匹配是很平常的,并不会引起开发人员晚上失眠 ,但是它确实存在,而且你必须要 考虑的事情。第二个不同是关联的不同,在1.2会碰到,数据库使用外键去表现关联,然而面向对象的应用程序使用引用,在下个部分我们会深入这个话题。
1.4.2  关联不匹配
当我们讨论Association的时候,关系和对象世界的最大不匹配是关系如何维护的,数据库表使用一个不同于类的机制。让我们检查两个世界的基数关系(一对一,多对多)是如何处理的。
一对一关系订单表拥有关于订单的所有数据,但是假设应用需要改进,一个额外的列需要添加到Order订单表,这可能看起来是一个很小的改进,因为添加一列并不是特别的危险,但是严重的不是这个,可能有很多的应用程序依赖于这个表,如果你不想避免引入Bug的话,机制的做法是创建一个新表,新表拥有一个OrderID和一个新列,从数据库方面来说,这是一个可以接受的折中方案但是在对象世界中重复这一的设计是无意义的,最好的方式是在Order类中添加一个属性。

同数据库交互的方法会处理两个模式之间的不同,这个方法一点都不复杂,它在两个表做了一个Join,并更新数据去处理这个不匹配
Select a.*, b.* from Orders a join Order2 on (a.orderid = b.orderid)
This association difference leads to the granularity mismatch, which will be discussed
later in this section.

Chapter1-data access reloaded:Entity Framework(下)的更多相关文章

  1. Chapter1-data access reloaded:Entity Framework(上)

    本章包括以下几个部分: 1.DataSet and classic ADO.NET approach2.Object model approach3.Object/relational mismatc ...

  2. How to: Supply Initial Data for the Entity Framework Data Model 如何:为EF数据模型提供初始数据

    After you have introduced a data model, you may need to have the application populate the database w ...

  3. SQL Server 2008 Data Types and Entity Framework 4

    Because I’ve had a lot of conversations about spatial data types lately, I thought I would create a ...

  4. What is Entity Framework?

    1.什么是EntityFramework? http://www.entityframeworktutorial.net/what-is-entityframework.aspx Writing an ...

  5. Entity Framework Tutorial Basics(2):What is Entity Framework?

    What is Entity Framework? Writing and managing ADO.Net code for data access is a tedious and monoton ...

  6. Entity Framework context per request

    原文发布时间为:2011-09-24 -- 来源于本人的百度文章 [由搬家工具导入] http://www.blog.cyberkinetx.com/2011/05/15/entity-framewo ...

  7. Access MongoDB Data with Entity Framework 6

    This article shows how to access MongoDB data using an Entity Framework code-first approach. Entity ...

  8. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 读取关系数据

    Reading related data¶ 9 of 9 people found this helpful The Contoso University sample web application ...

  9. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 增、查、改、删操作

    Create, Read, Update, and Delete operations¶ 5 of 5 people found this helpful By Tom Dykstra The Con ...

随机推荐

  1. PLSQL Developer连接数据库报错ora-12514解决

    连接本地数据库报以上错误,需要修改本地数据库的监听配置文件(如下所示:) 比如我的本地oracle数据库相关文件在E:\app\user\product\11.2.0\dbhome_1下 然后在E:\ ...

  2. Android获取屏幕大小(Px)

    private DisplayMetrics dm = new DisplayMetrics(); TextView tv; Button bu; @Override protected void o ...

  3. string和数值之间的转换

    string和数值之间的转换 to_string(val) 一组重载函数,返回数值val的string表示val可以是任何算数类型. stoi(s,p,b),stol(s,p,b),stoul(s,p ...

  4. Oracle数据库之初步接触

    每个Oracle数据库都是数据的集合,这些数据包含在一个或多个文件中.数据库有物理和逻辑两种结构.在开发应用程序的过程中,会创建诸如表和索引这样的结构,这些结构用于数据行的存储和查询.可以为对象的名称 ...

  5. luogu1856 [USACO5.5]矩形周长Picture

    看到一坨矩形就要想到扫描线.(poj atantis) 我们把横边竖边分开计算,因为横边竖边其实没有区别,以下论述全为考虑竖边的. 怎样统计一个竖边对答案的贡献呢?答:把这个竖边加入线段树,当前的总覆 ...

  6. 解决Can’t finish GitHub sharing process Successfully created project ‘GitHubDemo’ on GitHub

    Can't finish GitHub sharing process        Successfully created project 'KeyWordsFrameWork' on GitHu ...

  7. 【java基础 3】树形结构数据呈现的递归算法实现

    一.基本概况 在我的项目中,常常会用到树形结构的数据,最为明显的就是左边菜单栏,类似于window folder一样的东西. 而我之前一直是借助前端封装好的ZTree等工具实现展示,而后台则通常使用递 ...

  8. 【2017多校训练2+计算几何+板】HDU 6055 Regular polygon

    http://acm.hdu.edu.cn/showproblem.php?pid=6055 [题意] 给定n个格点,问有多少个正多边形 [思路] 因为是格点,只可能是正方形 枚举正方形的对角线,因为 ...

  9. HDU 1074 Doing Homework【状态压缩DP】

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题意: 给定作业截止时间和完成作业所需时间,比截止时间晚一天扣一分,问如何安排作业的顺序使得最 ...

  10. CodeForces 595A Vitaly and Night

    水题. #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> u ...