YashanDB ST_BUILDAREA函数

ST_BUILDAREA函数用于将输入的geometry中的线条组合成一个多边形。

本函数遵守如下规则:

  • 本函数针对二维空间对象,当输入的几何对象是三维对象时,输出结果仍为三维对象,但第三维坐标不参与计算。即计算过程中判断线圈是否闭合、是否存在空间包含关系时,只有前二维坐标参与计算,二维空间上闭合但三维空间不闭合的线圈,仍视为闭合。
  • 输入参数为NULL时,函数返回NULL。
  • 输入参数为空的几何对象时,函数返回一个空的多边形。
  • 输入参数为点、多点时,返回NULL。
  • 输入参数为一个LineString时,如果LineString为一个首尾闭合的线圈,则返回一个多边形,否则返回NULL。
  • 输入参数为一个多边形时,返回多边形。
  • 输入参数为集合对象(MultiLineString、MultiPolygon、GeometryCollection)时,函数的表现如下:
    • 如果某个成员单独执行ST_BuildArea返回NULL,则该成员不对结果产生影响。
    • 如果多个成员之间存在包含关系(例如一个线圈包含另外一个线圈,或一个多边形包含另一个多边形),则被包含的对象将被视为多边形的洞。
  • 返回的几何对象,其SRID与输入的几何对象一致。

geometry

通用表达式,其值必须为有效的ST_GEOMETRY类型的数据。

示例


SELECT st_astext(st_buildarea(st_geomfromtext('linestring(0 0, 4 0, 4 4, 0 4)')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR




SELECT st_astext(st_buildarea(st_geomfromtext('linestring(0 0, 4 0, 4 4, 0 4, 0 0)')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR

POLYGON ((0 0, 0 4, 4 4, 4 0, 0 0))

SELECT st_astext(st_buildarea(st_geomfromtext('polygon((0 0, 4 0, 4 4, 0 4, 0 0))')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR

POLYGON ((0 0, 0 4, 4 4, 4 0, 0 0))

SELECT st_astext(st_buildarea(st_geomfromtext('polygon((0 0, 4 0, 4 4, 0 4, 0 0),(2 2, 3 2, 3 3, 2 3, 2 2))')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR

POLYGON ((0 0, 0 4, 4 4, 4 0, 0 0), (2 2, 3 2, 3 3, 2 3, 2 2))


SELECT st_astext(st_buildarea(st_geomfromtext('multilinestring((0 0, 4 0, 4 4, 0 4, 0 0),(2 2, 3 2, 3 3, 2 3, 2 2))')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR

POLYGON ((0 0, 0 4, 4 4, 4 0, 0 0), (2 2, 3 2, 3 3, 2 3, 2 2))


SELECT st_astext(st_buildarea(st_geomfromtext('linestring(0 0 0, 4 0 0, 4 4 0, 0 4 0, 0 0 1)')), 0) FROM dual;

ST_ASTEXT(ST_BUILDAR

POLYGON Z ((0 0 1, 0 4 0, 4 4 0, 4 0 0, 0 0 0))

Copied!

posted @ 2025-05-20 11:37  YashanDB  阅读(4)  评论(0)    收藏  举报