2024年9月26日:PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:开发版本
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1

8.8. 几何类型 #

几何数据类型表示二维空间对象。 表 8.20 显示了 PostgreSQL 中可用的几何类型。

表 8.20. 几何类型

名称 存储大小 描述 表示
point 16 字节 平面上的点 (x,y)
line 24 字节 无限长直线 {A,B,C}
lseg 32 字节 有限线段 [(x1,y1),(x2,y2)]
box 32 字节 矩形框 (x1,y1),(x2,y2)
path 16+16n 字节 闭合路径(类似于多边形) ((x1,y1),...)
path 16+16n 字节 开放路径 [(x1,y1),...]
polygon 40+16n 字节 多边形(类似于闭合路径) ((x1,y1),...)
circle 24 字节 <(x,y),r>(圆心和半径)

在所有这些类型中,各个坐标都存储为 double precision (float8) 数。

提供了一套丰富的函数和运算符来执行各种几何运算,例如缩放、平移、旋转和确定交点。它们在 第 9.11 节 中进行了说明。

8.8.1. 点 #

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

( x , y )
  x , y

其中 xy 分别是坐标,作为浮点数。

点使用第一种语法输出。

8.8.2. 线 #

线由线性方程 Ax + By + C = 0 表示,其中 AB 不都为零。类型 line 的值以以下形式输入和输出

{ A, B, C }

或者,可以将以下任何形式用于输入

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

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

8.8.3. 线段 #

线段由两点表示,这两点是线段的端点。类型 lseg 的值可以使用以下语法之一指定

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

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

线段使用第一种语法输出。

8.8.4. 盒 #

盒由两点表示,这两点是盒的对角顶点。类型 box 的值可以使用以下语法之一指定

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

其中 (x1,y1)(x2,y2) 是盒的任何两个对角顶点。

盒使用第二种语法输出。

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

8.8.5. 路径 #

路径由连接点的列表表示。路径可以是 开放的,其中列表中的第一个和最后一个点被认为未连接,或者 闭合的,其中第一个和最后一个点被认为是连接的。

类型 path 的值可以使用以下语法之一指定

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

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

路径使用第一或第二种语法输出,具体取决于情况。

8.8.6. 多边形 #

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

多边形和路径之间一个重要的实现差异是,多边形的存储表示形式包括其最小的边界框。这加快了某些搜索操作的速度,尽管在构建新多边形时计算边界框会增加开销。

类型 polygon 的值可以使用以下语法之一指定

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

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

多边形使用第一种语法输出。

8.8.7. 圆 #

圆由圆心和半径表示。类型 circle 的值可以使用以下语法之一指定

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

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

圆使用第一种语法输出。

提交更正

如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步澄清的内容,请使用 此表单 报告文档问题。