【PostgreSQL】从零开始:(二十三)数据类型-几何类型

发布时间:2023年12月23日

几何(Geometric Types)类型


概述


几何(Geometric Types)类型也称几何数据表示二维空间对象。在PostgreSQL数据库中,有几种几何类型用于存储和处理空间数据。这些几何类型是通过PostGIS扩展提供的,它是一个为地理和空间数据提供支持的强大的开源库。

几何类型可以存储在PostgreSQL数据库的表中的列中,可以进行空间查询、分析和操作。

几何类型

名字存储大小描述表示法
point16 字节平面上的点(x,y)
line32 字节无限线{A,B,C}
lseg32 字节有限线段((x1,y1),(x2,y2))
box32 字节长方形盒子((x1,y1),(x2,y2))
path16+16n 字节闭合路径(类似于多边形)((x1,y1),...)
path16+16n 字节开放路径[(x1,y1),...]
polygon40+16n 字节多边形(类似于闭合路径)((x1,y1),...)
circle24 字节<(x,y),r>(中心点和半径)

?PostgreSQL提供了丰富的几何计算函数与运算符。

Point(点)

点是几何类型的基本二维构建块。使用以下任一语法指定 point的值:

( x , y )
  x , y

其中?x?和?y?是各自的坐标,作为浮点数。

Line(线)

直线由线性方程 A x + B y +?C?= 0 表示,其中?A和?B?不都为零。line类型的值是输入和输出,格式如下:

{ A, B, C }
[ ( x1 , y1 ) , ( x2 , y2 ) ]
( ( x1 , y1 ) , ( x2 , y2 ) )
  ( x1 , y1 ) , ( x2 , y2 )
    x1 , y1   ,   x2 , y2

其中(x1,y1)(x2,y2)是线上的两个不同点。

Line Segments(线段)

线段由作为线段端点的点对表示。使用以下任一语法指定lseg类型的值,和线的方法类似:

[ ( x1 , y1 ) , ( x2 , y2 ) ]
( ( x1 , y1 ) , ( x2 , y2 ) )
  ( x1 , y1 ) , ( x2 , y2 )
    x1 , y1   ,   x2 , y2

其中 (x1,y1)(x2,y2)是线段的端点。

Boxes(方框)

方框由方框相对角的点对表示。使用以下任一语法box指定类型的值:

( ( x1 , y1 ) , ( x2 , y2 ) )
  ( x1 , y1 ) , ( x2 , y2 )
    x1 , y1   ,   x2 , y2

其中(x1,y1)(x2,y2)方框的任意两个相对角。

可以在输入时提供任何两个相对的角,但值将根据需要重新排序,以按该顺序存储右上角和左下角。

Paths(路径)

路径由连接点列表表示。路径可以是打开的,其中列表中的第一个和最后一个点被视为未连接,也可以是关闭的,其中第一个和最后一个点被视为已连接。

使用以下任一语法指定path类型的值:

[ ( x1 , y1 ) , ... , ( xn , yn ) ]
( ( x1 , y1 ) , ... , ( xn , yn ) )
  ( x1 , y1 ) , ... , ( xn , yn )
  ( x1 , y1   , ... ,   xn , yn )
    x1 , y1   , ... ,   xn , yn

其中,这些点是构成路径的线段的端点。方括号 []表示开放路径,而括号()表示封闭路径。当省略最外层的括号时,如在第三到第五语法中,假定为闭合路径。

Polygons(多边形)

多边形由点列表(多边形的顶点)表示。多边形与闭合路径非常相似;本质区别在于,多边形被认为包含其中的区域,而路径则不然。

使用以下任一语法指定polygon类型的值:

( ( x1 , y1 ) , ... , ( xn , yn ) )
  ( x1 , y1 ) , ... , ( xn , yn )
  ( x1 , y1   , ... ,   xn , yn )
    x1 , y1   , ... ,   xn , yn

其中,这些点是构成多边形边界的线段的端点。

Circle(圆)

圆由中心点和半径表示。使用以下任一语法指定circle类型的值:

< ( x , y ) , r >
( ( x , y ) , r )
  ( x , y ) , r
    x , y   , r

其中(x,y)是中心点,r 是圆的半径。

文章来源:https://blog.csdn.net/sinat_36528886/article/details/135118905
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。