名称

ST_Relate — 测试两个几何图形是否具有与交集矩阵模式匹配的拓扑关系,或计算它们的交集矩阵

概要

boolean ST_Relate(geometry geomA, geometry geomB, text intersectionMatrixPattern);

text ST_Relate(geometry geomA, geometry geomB);

text ST_Relate(geometry geomA, geometry geomB, integer boundaryNodeRule);

描述

这些函数允许测试和评估两个几何图形之间的空间(拓扑)关系,如维度扩展的 9 交集模型 (DE-9IM) 所定义。

DE-9IM 被指定为一个 9 元素矩阵,指示两个几何图形的内部、边界和外部之间的交集维度。它由一个 9 字符的文本字符串表示,使用符号 'F'、'0'、'1'、'2'(例如 'FF1FF0102')。

可以通过将交集矩阵与交集矩阵模式匹配来测试特定的空间关系。模式可以包括额外的符号 'T'(表示“交集非空”)和 '*'(表示“任何值”)。常用的空间关系由命名函数 ST_Contains, ST_ContainsProperly, ST_Covers, ST_CoveredBy, ST_Crosses, ST_Disjoint, ST_Equals, ST_Intersects, ST_Overlaps, ST_TouchesST_Within 提供。使用显式模式可以一步测试相交、交叉等的多个条件。它还允许测试没有命名空间关系函数的空间关系。例如,关系“内部相交”具有 DE-9IM 模式 T********,这不会被任何命名谓词评估。

有关更多信息,请参阅第 5.1 节,“确定空间关系”

变体 1:测试两个几何图形是否根据给定的 intersectionMatrixPattern 在空间上相关。

[Note]

与大多数命名的空间关系谓词不同,这不自动包括索引调用。原因是某些关系对于不相交的几何图形(例如 Disjoint)为真。如果您正在使用需要相交的关系模式,则包括 && 索引调用。

[Note]

如果可以使用命名关系函数,则最好使用它,因为它们会自动使用存在的空间索引。此外,它们可能会实现完整的相关评估无法获得的性能优化。

变体 2:返回两个输入几何图形之间空间关系的 DE-9IM 矩阵字符串。可以使用 ST_RelateMatch 测试矩阵字符串是否匹配 DE-9IM 模式。

变体 3:与变体 2 类似,但允许指定边界节点规则。边界节点规则允许更精细地控制 MultiLineString 的端点是否被认为位于 DE-9IM 内部或边界中。boundaryNodeRule 值如下

  • 1OGC-Mod2 - 如果线端点出现奇数次,则它们位于边界中。这是 OGC SFS 标准定义的规则,也是 ST_Relate 的默认规则。

  • 2Endpoint - 所有端点都在边界中。

  • 3MultivalentEndpoint - 如果端点出现多次,则它们位于边界中。换句话说,边界是所有“附加”或“内部”端点(而不是“未附加/外部”端点)。

  • 4MonovalentEndpoint - 如果端点仅出现一次,则它们位于边界中。换句话说,边界是所有“未附加”或“外部”端点。

此函数不在 OGC 规范中,但隐含在其中。请参阅 s2.1.13.2

此方法实现了OGC SQL 1.1 简单要素实现规范。s2.1.1.2 // s2.1.13.3

此方法实现了 SQL/MM 规范。SQL-MM 3: 5.1.25

由 GEOS 模块执行

增强:2.0.0 - 添加了对指定边界节点规则的支持。

[Important]

增强:3.0.0 启用了对 GEOMETRYCOLLECTION 的支持

示例

使用布尔值函数测试空间关系。

SELECT ST_Relate('POINT(1 2)', ST_Buffer( 'POINT(1 2)', 2), '0FFFFF212');
st_relate
-----------
t

SELECT ST_Relate(POINT(1 2)', ST_Buffer( 'POINT(1 2)', 2), '*FF*FF212');
st_relate
-----------
t

将自定义空间关系模式作为查询条件进行测试,使用 && 以启用使用空间索引。

-- Find compounds that properly intersect (not just touch) a poly (Interior Intersects)

SELECT c.* , p.name As poly_name
    FROM polys AS p
    INNER JOIN compounds As c
          ON c.geom && p.geom
             AND ST_Relate(p.geom, c.geom,'T********');

计算空间关系的交集矩阵。

SELECT ST_Relate( 'POINT(1 2)',
                  ST_Buffer( 'POINT(1 2)', 2));
-----------
0FFFFF212

SELECT ST_Relate( 'LINESTRING(1 2, 3 4)',
                  'LINESTRING(5 6, 7 8)' );
-----------
FF1FF0102

使用不同的边界节点规则来计算 LineString 和具有重复端点 (3 3) 的 MultiLineString 之间的空间关系

  • 使用OGC-Mod2规则 (1),重复的端点位于 MultiLineString 的内部,因此 DE-9IM 矩阵条目 [aB:bI] 为 0,[aB:bB] 为 F

  • 使用 Endpoint 规则 (2),重复的端点位于 MultiLineString 的边界,因此 DE-9IM 矩阵条目 [aB:bI] 为 F,[aB:bB] 为 0

WITH data AS (SELECT
  'LINESTRING(1 1, 3 3)'::geometry AS a_line,
  'MULTILINESTRING((3 3, 3 5), (3 3, 5 3))':: geometry AS b_multiline
)
SELECT ST_Relate( a_line, b_multiline, 1) AS bnr_mod2,
       ST_Relate( a_line, b_multiline, 2) AS bnr_endpoint
    FROM data;

 bnr_mod2  | bnr_endpoint
-----------+--------------
 FF10F0102 | FF1F00102