PostgreSQL和面向对象数据库有什么关系?
百科里面介绍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是一个优秀的从关系型数据库向面向对象数据库过渡的产品。
原创文章,文章首发于:Riley Ge (@rileyge) — Steemit
原创文章,转载请注明: 转载自TsonTec:测量解决方案提供者
本文链接地址: PostgreSQL和面向对象数据库有什么关系?
说点什么