名称

ST_RelateMatch — 测试 DE-9IM 交集矩阵是否匹配交集矩阵模式

概要

boolean ST_RelateMatch(text intersectionMatrix, text intersectionMatrixPattern);

描述

测试 维度扩展 9 交集模型 (DE-9IM) intersectionMatrix 值是否满足 intersectionMatrixPattern。 交集矩阵值可以通过 ST_Relate 计算。

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

由 GEOS 模块执行

可用性:2.0.0

示例

SELECT ST_RelateMatch('101202FFF', 'TTTTTTFFF') ;
-- result --
t

针对交集矩阵值匹配的常见空间关系模式,用于相对于多边形的不同位置的线

SELECT pat.name AS relationship, pat.val AS pattern,
       mat.name AS position, mat.val AS matrix,
       ST_RelateMatch(mat.val, pat.val) AS match
    FROM (VALUES ( 'Equality', 'T1FF1FFF1' ),
                 ( 'Overlaps', 'T*T***T**' ),
                 ( 'Within',   'T*F**F***' ),
                 ( 'Disjoint', 'FF*FF****' )) AS pat(name,val)
    CROSS JOIN
        (VALUES  ('non-intersecting', 'FF1FF0212'),
                 ('overlapping',      '1010F0212'),
                 ('inside',           '1FF0FF212')) AS mat(name,val);

 relationship |  pattern  |     position     |  matrix   | match
--------------+-----------+------------------+-----------+-------
 Equality     | T1FF1FFF1 | non-intersecting | FF1FF0212 | f
 Equality     | T1FF1FFF1 | overlapping      | 1010F0212 | f
 Equality     | T1FF1FFF1 | inside           | 1FF0FF212 | f
 Overlaps     | T*T***T** | non-intersecting | FF1FF0212 | f
 Overlaps     | T*T***T** | overlapping      | 1010F0212 | t
 Overlaps     | T*T***T** | inside           | 1FF0FF212 | f
 Within       | T*F**F*** | non-intersecting | FF1FF0212 | f
 Within       | T*F**F*** | overlapping      | 1010F0212 | f
 Within       | T*F**F*** | inside           | 1FF0FF212 | t
 Disjoint     | FF*FF**** | non-intersecting | FF1FF0212 | t
 Disjoint     | FF*FF**** | overlapping      | 1010F0212 | f
 Disjoint     | FF*FF**** | inside           | 1FF0FF212 | f

另请参阅

第 5.1 节,“确定空间关系”ST_Relate