博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
弥合对象/关系之间的鸿沟(三)—— 阻抗不匹配?
阅读量:5230 次
发布时间:2019-06-14

本文共 984 字,大约阅读时间需要 3 分钟。

弥合对象/关系之间的鸿沟(三)

 

阻抗不匹配?

 

  所谓的对象和数据库模式(schema)之间的阻抗不匹配产生了很多讨论,这当然有很好的理由。根据斯科特·安布勒3所说的,这两种技术之间具有“欺骗性的相似之处”。对这两种技术之间的差异缺乏了解可能会导致选择糟糕的设计并导致项目失败。

  在对象语言中(如Java)数据模型并不是完全与关系型数据库中的相同,所以必须特别小心防止出现问题。例如,字符列的最大长度必须在关系模式中指定,然而Java字符串的最大长度基本上是无限的。

  浮点数也可能会导致问题。Java实现了IEEE浮点数;但不同的关系型数据库往往有不同的表示。结果导致,并非所有Java中的浮点数值可以存储在数据库中,反之亦然。

  甚至固定精度的十进制数映射到关系模式时,也可能会造成问题。Java支持的固定精度的十进制数是自描述的,也就是说,每个值都有自己特定的精度(数字总位数)和标度(小数点右边的数字位数)。然而,在数据库中,同一列中的所有数字具有相同的精度和标度。

  应用程序领域类和数据库模式并不是同结构的,它们的映射是通过设计完成的。领域模型方面,对象模型的某些方面不映射到数据库中,包括类的行为和类的变量。在关系型数据库方面,并不是数据库中每个模式的所有表和列在领域模型中都有所表示,存储过程也一样。此外,领域模型可能有数种合法的映射。

  用一个领域对象模型表示一个数据库模式通常很简单直观,如果此模式(schema)被很好的规范化时,更是特别如此。在实体-关系模型的模式(schema)中,每一个实体映射到一个领域类。每一个简单的关系被实现为一个模式中的外键,关系的一方被映射一个引用类型的字段,另一方被映射为一个多值类型的字段。 

  实体-关系模型中的许多复杂的结构,可以很好地映射到对象-模型结构。例如,一个的连接表(它的两个列是指向两个不同表的外键)可以映射到两个类,其中每个类都包含一个字段,每个字段的类型都是另一个类的对象集合。

  另一方面,在关系型数据库中存储任意一个领域对象模型也可能是具有挑战性的。使用抽象类、深继承或接口表示模型之间关系的情况下,通常存储和检索的性能很差。

 

 

下一篇

 

转载于:https://www.cnblogs.com/scottgu/archive/2012/04/08/2437976.html

你可能感兴趣的文章
不错的MVC文章
查看>>
IOS Google语音识别更新啦!!!
查看>>
[置顶] Linux终端中使用上一命令减少键盘输入
查看>>
BootScrap
查看>>
路冉的JavaScript学习笔记-2015年1月23日
查看>>
Mysql出现(10061)错误提示的暴力解决办法
查看>>
2018-2019-2 网络对抗技术 20165202 Exp3 免杀原理与实践
查看>>
NPM慢怎么办 - nrm切换资源镜像
查看>>
Swift - UIView的常用属性和常用方法总结
查看>>
Swift - 异步加载各网站的favicon图标,并在单元格中显示
查看>>
【Python学习笔记】1.基础知识
查看>>
梦断代码阅读笔记02
查看>>
selenium学习中遇到的问题
查看>>
大数据学习之一——了解简单概念
查看>>
Linux升级内核教程(CentOS7)
查看>>
Lintcode: Partition Array
查看>>
Maximum Product Subarray
查看>>
[转载] MySQL的四种事务隔离级别
查看>>
QT文件读写
查看>>
C语言小项目-火车票订票系统
查看>>