名稱

ST_ClusterIntersectingWin — 視窗函數,為每個輸入幾何圖形返回一個群集 ID,將輸入幾何圖形群集為連接的集合。

概要

integer ST_ClusterIntersectingWin(geometry winset geom);

描述

一個視窗函數,用於建立相交幾何圖形的連接群集。 可以遍歷一個群集中的所有幾何圖形而不離開該群集。 返回值是幾何圖形參數所參與的群集編號,或者對於空輸入返回 null。

可用性:3.4.0

範例

WITH testdata AS (
  SELECT id, geom::geometry FROM (
  VALUES  (1, 'LINESTRING (0 0, 1 1)'),
          (2, 'LINESTRING (5 5, 4 4)'),
          (3, 'LINESTRING (6 6, 7 7)'),
          (4, 'LINESTRING (0 0, -1 -1)'),
          (5, 'POLYGON ((0 0, 4 0, 4 4, 0 4, 0 0))')) AS t(id, geom)
)
SELECT id,
  ST_AsText(geom),
  ST_ClusterIntersectingWin(geom) OVER () AS cluster
FROM testdata;

 id |           st_astext            | cluster
----+--------------------------------+---------
  1 | LINESTRING(0 0,1 1)            |       0
  2 | LINESTRING(5 5,4 4)            |       0
  3 | LINESTRING(6 6,7 7)            |       1
  4 | LINESTRING(0 0,-1 -1)          |       0
  5 | POLYGON((0 0,4 0,4 4,0 4,0 0)) |       0