PostgreSQL和面向对象数据库有什么关系?

嘎子 面向对象数据库 2016-01-30 838 次浏览 , , , 没有评论

百科里面介绍PostgreSQL的第一句话是:PostgreSQL是自由的对象-关系数据库服务器(数据库管理系统)。我一直对对象-关系数据库的概念比较模糊,所以在网上搜索了一下PostgreSQL和MySQL的关系,对比之类的。会发现这些对比里面完全没有对象的事,那PostgreSQL为什么被称为对象-关系数据库呢?他的对象特性显示在哪里?他的对象特性对于性能及编程速度有多大的影响?

关于性能及一些优势什么的我就不一一说明了,网上现在有很多。我觉得我和多数人一样,最先接触了MySQL,后来就一直用着,也无所谓好坏。现在我只说一下PostgreSQL中的对象特性作一些介绍。

首先我要说明一点,自己是一个PostgreSQL的新手,今天想要研究这个问题才翻看一遍PostgreSQL的手册,然后结合自己的知识发表一些看法,如果有不正确的地方大家一定要指出,然后相互学习,共同进步。

PostgreSQL的对象特性可以用一句话表示:在PostgreSQL中每一个表都被当成了一个对象的集合,可以与其他的表之间有继承关系。当然PostgreSQL也用自己的方法对表与表之间进行继承可能出现的问题进行了合理化的解决。第一点是PostgreSQL中有复合类型的存在,类似于面向对象的编程语言中的结构(但是这种复合类型也是用表实现的),也有数组。

PostgreSQL对表和对象的处理很容易让人想到ORM(Object Relational Mapping,即对象关系映射),他的想法是提供给用户一种面向对象数据库的错觉,但实际上数据存储是用关系表来进行的。但是从现在的应用来看,大家只把PostgreSQL当成一种普通的RDBMS和MySQL来进行对比与对抗,并没有把他对象的特性弃用利用起来。

最后说一下这个特性的影响吧。首先是性能,这个我没有发言权,网上非常多的对比分析,大家可以看一下。第二就是对编程的影响:我使用最多的是Microsoft的ADO.NET来访问数据库,所以仅仅从数据库的访问上并没有太大的编程效率的提高,但是PostgreSQL给人的感觉是非常容易实现一个通用的ORM,如果在一个通用的ORM的基础上,PostgreSQL甚至可以将编程的效率提高到和面向对象数据库达到相同的效果,毕竟编程的用户一般并不关心数据最终是如何存储的。

最后总结一下,PostgreSQL是一个优秀的从关系型数据库向面向对象数据库过渡的产品。

原创文章,转载请注明: 转载自TsonTec:测量解决方案提供者

本文链接地址: PostgreSQL和面向对象数据库有什么关系?

相关主题

  • 翻译系列文章之–面向对象数据库(Object Oriented Databases)2016-01-30 翻译系列文章之–面向对象数据库(Object Oriented Databases) (0)
    面向对象数据库也被称为对象数据管理系统。对象数据库存储面向对象编程语言(如Smalltalk,C++,java等)中的对象而不仅仅像关系数据库那样存储整数,字 […]
  • db4o官方停止支持及面向对象数据库的一些感想2016-01-30 db4o官方停止支持及面向对象数据库的一些感想 (0)
    前一段时间试用了db4o,真心觉得不错,觉得面向对象的数据库没有一个系统的论坛,所以自己建立了这个网站来推广。但今天在打开db4o的官方网站时发现Versan […]
  • 翻译系列文章之–面向对象数据库特征及用途(Object Database Use and Features)2016-02-01 翻译系列文章之–面向对象数据库特征及用途(Object Database Use and Features) (0)
    数据库为用户提供了数据持久化的功能,具体到对象数据库是指对象能够在不同的数据库进程之间进行存储。  产品特点  下面的列表是对 […]
  • 面向对象数据库是数据认识世界的方向2016-01-29 面向对象数据库是数据认识世界的方向 (0)
    像面向对象的编程语言一样,面向对象数据库(OOD)是数据走向更亲和真实世界的一种发展方向。 面向对象是一种认识方法学,也是一种新的程序设计方法学。把面向 […]
  • db4o基础与入门2016-01-29 db4o基础与入门 (0)
    如果你使用的编程语言是java或者.net(笔者最常用的编程语言为C#,所以下文中以C#说事,请读者勿怪),那你有福气了,db4o可以说是一种最自然的数 […]
  • 面向对象数据库及db4o的优势2016-01-29 面向对象数据库及db4o的优势 (0)
    这是这一系列文章的第一篇,所以不会说一些具体的见容,如果大家已经决定开始用db4o,而且大家对一些理论不太感兴趣的话,大家可以跳过这篇文章。当然这篇文章的所说 […]

说点什么

您将是第一位评论人!

提醒
avatar
wpDiscuz
回顶部