面向对象数据库(Object Oriented Databases)

前面说几句费话。现在正在从事面向对象数据库在国内的推广工做,假设有兴趣可以与我联系。

假设有不论什么问题可以私信我,也可以到咱们站点上 面向对象数据库交流社区 来向我提问,我必定以最快的速度解答。html

想把 面向对象数据库交流社区 打形成为国内最大的面向对象数据交流的社区,但愿有兴趣的与我共同经营这个社区。如下的译文。


面向对象数据库也被称为对象数据管理系统。对象数据库存储面向对象编程语言(如Smalltalk,C++,java等)中的对象而不仅像关系数据库那样存储整数,字符串和实数等。

对象通常由下面几部分构成:

--属性:属性量化对象的特征,这些量有多是简单的整数,字符串或者实数。也有多是一个复杂的对象。java


--方法:方法也一般被称为过程或者函数,方法规定了对象的行为。

所以。对象包括可运行的代码和数据。固然对象也有其它特征,好比一个方法或者数据可否在对象之外获取到。但是为了咱们的文章简单易懂并应用到面向对象数据库中,在本文中咱们不考虑这些。另一个需要要说起的东西是“类”。数据库

类在面向对象编程中用来规定一个对象包括哪些方法和数据。类就像对象的模板同样。编程

类自己并不包括方法和数据,但规定了对象中要包括什么方法和数据。在对象建立过程当中要用到类。在面向对象数据库中类用来建立对象中没有被存储在数据库中的部分(如对象的方法)。架构



与关系型数据库的对照

关系型数据库将数据存储在包括行和列的二维的表格中。由于关系型数据库表格被“格式化”了,因此数据不会有太多的反复。并发

所有的列都依赖于主键(列中的惟一值)来识别这一列。编程语言

可以用特定列的特定值来获取或者更改某一行的值。分布式


为了把对象放到关系表中,必实用字符串、整数、实数等简单数据来描写叙述这个类。函数

好比要描写叙述飞机,飞机机翼会用一个独立的表格来描写叙述它的尺寸等特性,机身用另一个表描写叙述。螺旋桨、轮胎等也用单独的表。诸如此类。
把复杂的信息分解成简单的信息要耗费劳动力,这里必需要编码代码完毕。

对象持久化

在传统的数据库中。在程序中被操做的数据是暂时的,存储在数据库中的数据是持久化的(存储在永久的存储设备上)。在面向对象数据库中。程序可以操做暂时数据和持久化后的数据。工具



什么时候使用面向对象数据

假设程序操纵很是复杂的数据或者数据的相对关系比較复杂时使用面向对象的数据库,特别是多对多的对象关系。

假设数据很是少有连接或者有大量数据时最好不要使用面向对象数据库。

面向对象数据库适用于:

--计算机辅助造型程序(计算机辅助软件project、计算机辅助设计、计算机辅助制造)
--多媒体程序
--随时间变化的项目project类软件
--商贸软件

面向对象数据库优点

--对象不需要装箱和拆箱操做,节省编程和运行时间。


--下降分页
--易于导航
--更好的并发控制 - 对象的层次结构可能被锁定。
--数据模型基于现实世界。
--在分布式架构状态下可以很是好的工做。


--假设程序也是面向对象的可以下降代码量。

面向对象数据库的劣势

--假设数据及数据间的关系相对简单则面向对象数据库效率较低。
--关系表更简单易懂。
--后期绑定可能拖慢訪问速度。
--关系数据库有不少其它的工具。


--关系数据库的标准更加稳定。
--RDBMS的服务和支持更加稳定,不需要更改。



ODBMS标准

--对象数据管理组(Object Data Management Group)
--对象数据库标准ODM6.2.0(Object Database Standard ODM6.2.0)
--对象查询语言(Object Query Language)
--对象查询语言支持SQL92(OQL support of SQL92)

数据怎样存储

不一样的数据库提供商使用两个主要的方法来存储数据。
--每一个对象包括惟一的ID,并定义为一个基本类的子类,用继承的方法来肯定牲。
--用虚拟内存映射来存储及管理对象。
传输数据是以对象为基础或者页面(一般为4K)为基础。



----文章原文:http://www.comptechdoc.org/ind ... .html。假设翻译有误。请指正。

此文章也在 http://ood.tson.com/article/9 刊载,欢迎评论。

相关文章
相关标签/搜索