PostGIS简介

空间数据管理问题及解决方案

空间数据特征:空间位置、非结构化、空间关系、分类编码、海量数据等。
一般的数据库管理系统难以满足要求。

为了提高DBMS对空间数据的管理能力,国内外先后出现过:文件与关系数据库混合管理系统、全关系型空间数据库管理系统、关系型 数据库+空间数据引擎扩展对象关系型数据库管理系统,以及面向对象空间数据库管理系统等多种解决方案。

目前国内外比较流行的解决方案是这两种:

  • 关系型数据库+空间数据引擎
    这是一种中间件解决方案,空间数据引擎负责组织空间数据的存储和读取,关系型数据库仅仅是存放空间数据的容器。
  • 典型代表:ESRI的ArcSDE 和 MapInfo的SpatialWare
  • 优点:访问速度快,简单易实现
  • 缺点:空间操作和处理与数据库内核剥离,数据模型复杂,拓展困难,数据共享困难
  • 扩展对象关系型数据库
    这是一种新型数据库解决方案,既然传统关系型数据库难以管理非结构化数据,那就开发一种新型数据来实现它,即对象关系型数据库。
  • 典型代表:Oracle 的 Oracle Spatial, IBM 的 DB2 Spatial Extender, Informix 的 Spatial DataBlade
  • 优点:空间数据的管理与数据库融为一体,扩展方便,数据共享易实现
  • 缺点:实现难度大,数据压缩困难,功能和性能与第一种方案尚存在差距

PostgreSQL是目前开源空间信息软件领域性能最优的数据库,构建在其上的空间对象扩展模块PostGIS使其成为一个真正的大型空间数据库。

从PostgreSQL到PostGIS

PostgreSQL中已经提供了一些空间特性:

  • 定义了一些基本的集合实体类型
  • 定义了一系列的函数和操作符来实现几何类型的操作和运算
  • 引入空间数据索引

但其提供的空间特性还不能达到要求,主要表现在:

  • 缺乏复杂的空间类型
  • 没有提供空间分析
  • 没有提供投影变换功能

这些问题的存在导致费时费力、产品复杂、性能低下,这些原因促成了PostGIS的实施。

在介绍PostgreSQL的部分中我们已经提到过,文件页(磁盘块)是物理存储的最小单位,默认大小是8k,最大可设置为2^15字节。

在PostgreSQL 7.1版本之前,支持的记录大小最大为8k,空间数据对象往往会超过8k,这一限制导致空间数据的存储无从谈起。

从7.1版本开始,PostgreSQL摒弃了这一限制,PostGIS的实现变为可能。

PostGIS特性与功能

  • PostGIS支持所有的空间数据类型
    这些类型包括:点(POINT)、线(LINESTRING)、多边形(POLYGON)、多点 (MULTIPOINT)、多线(MULTILINESTRING)、多多边形(MULTIPOLYGON)和集合对象集 (GEOMETRYCOLLECTION)等。

  • PostGIS支持所有的对象表达方法
    比如WKT和WKB。

  • PostGIS支持所有的数据存取和构造方法
    如GeomFromText()、AsBinary(),以及GeometryN()等。

  • PostGIS提供简单的空间分析函数
    如Area和Length
    同时也提供其他一些具有复杂分析功能的函数
    比如Distance。

  • PostGIS提供了对于元数据的支持
    如GEOMETRY_COLUMNS和SPATIAL_REF_SYS
    同时,PostGIS也提供了相应的支持函数
    如AddGeometryColumn和DropGeometryColumn。

  • PostGIS提供了一系列的二元谓词(如Contains、Within、Overlaps和Touches)用于检测空间对象之间的空间关系,同时返回布尔值来表征对象之间符合这个关系。

  • PostGIS提供了空间操作符(如Union和Difference)用于空间数据操作
    比如,Union操作符融合多边形之间的边界。两个交迭的多边形通过Union运算就会形成一个新的多边形,这个新的多边形的边界为两个多边形中最大边界。

PostGIS还提供以下功能:

  • 数据库坐标变换
    数据库中的几何类型可以通过Transform函数从一种投影系变换到另一种投影系中。在OpenGIS中的几何类型都将SRID作为自身结构的一部分,但不知什么原因,在OpenGIS的SFSQL规范中,并没有引入Transform。

  • 球体长度运算
    存储在普通地理坐标系中的集合类型如果不进行坐标变换是无法进行程度运算的,OpenGIS所提供的坐标变换使得积累类型的程度计算变成可能。

  • 三维的几何类型
    SFSQL规范只是针对二维集合类型。OpenGIS提供了对三维集合类型的支持,具体是利用输入的集合类型维数来决定输出的表现方式。例如,即便 所有几何对象内部都以三维形式存储,纯粹的二维交叉点通常还是以二维的形式返回。此外,还提供几何对象在不同维度间转换的功能。

  • 空间聚集函数
    在数据库中,聚集函数是一个执行某一属性列所有数据操作的函数。比如Sum和Average,Sum是求某一关系属性列的数据总和,Average 则是求取某一关系属性列的数据平均值。与此对应,空间聚集函数也是执行相同的操作,不过操作的对象是空间数据。例如聚集函数Extent返回一系列要素中 的最大的包裹矩形框,如“SELECT EXTENT(GEOM) FROM ROADS”这条SQL语句的执行结果是返回ROADS这个数据表中所有的包裹矩形框。

  • 栅格数据类型
    PostGIS通过一种新的数据类型片,提供对于大的栅格数据对象的存储。片由以下几个部分组成:包裹矩形框、SRID、类型和一个字节序列。通过 将片的大小控制在数据库页值(32×32)以下,使得快速的随即访问变成可能。一般大的图片也是通过将其切成32×32像素的片然后再存储在数据库中的。

DBMS管理空间数据问题的发展方向

“关系型数据库+空间数据引擎”技术方案访问迅速,与GIS联系紧密,在应用中占有一定优势。问题是引擎与数据库内核独立,难以利用数据库系统中已有的成熟的管理、访问技术,在进一步发展上有致命弱点。

“面向对象空间数据库系统”技术方案从理论上来看,是最适用于空间数据的表达和管理的。但是由于在访问速度的问题上尚未有重大突破,在一段时间内都无法替代“对象关系型数据库系统”。

扩展对象关系型数据库管理系统技术方案尽管在性能上和“关系型数据库+空间数据引擎”技术方案仍有一定差距,但随着技术的发展,将是解决这一问题的发展方向。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容