ST_DumpSegments — Gibt eine Zusammenfassung des Inhalts einer Geometrie wieder.
geometry_dump[] ST_DumpSegments(
geometry geom)
;
Eine Funktion, die eine Menge zurückgibt (SRF), die die Segmente einer Geometrie extrahiert. Sie gibt einen Satz von geometry_dump Zeilen zurück, die jeweils eine Geometrie (Feldgeom
) und eine Reihe von Ganzzahlen (Feldpath
) enthalten.
Die Felder geom
LINESTRING
s stellen die linearen Segmente der gelieferten Geometrie dar, während die Felder CIRCULARSTRING
s die Bogensegmente darstellen.
Das Feld path
(ein integer[]
) ist ein Index, der die Positionen der Segmentstartpunkte in den Elementen der gelieferten Geometrie auflistet. Die Indizes sind 1-basiert. Zum Beispiel sind für einen LINESTRING
die Pfade {i}
wobei i
der n-te
Segmentstartpunkt im LINESTRING
ist. Für ein POLYGON
lauten die Pfade {i,j}
, wobei i
die Ringnummer ist (1 ist der äußere, die inneren Ringe folgen) und j
die Position des Segment-Startpunkts im Ring.
Verfügbarkeit: 3.2.0
Diese Funktion unterstützt Dreiecke und dreieckige unregelmäßige Netzoberflächen (TIN).
Diese Funktion unterstützt 3d und lässt den Z-Index nicht fallen.
SELECT path, ST_AsText(geom) FROM ( SELECT (ST_DumpSegments(g.geom)).* FROM (SELECT 'GEOMETRYCOLLECTION( LINESTRING(1 1, 3 3, 4 4), POLYGON((5 5, 6 6, 7 7, 5 5)) )'::geometry AS geom ) AS g ) j; path │ st_astext --------------------------------- {1,1} │ LINESTRING(1 1,3 3) {1,2} │ LINESTRING(3 3,4 4) {2,1,1} │ LINESTRING(5 5,6 6) {2,1,2} │ LINESTRING(6 6,7 7) {2,1,3} │ LINESTRING(7 7,5 5) (5 rows)
-- Triangle -- SELECT path, ST_AsText(geom) FROM ( SELECT (ST_DumpSegments(g.geom)).* FROM (SELECT 'TRIANGLE(( 0 0, 0 9, 9 0, 0 0 ))'::geometry AS geom ) AS g ) j; path │ st_astext --------------------------------- {1,1} │ LINESTRING(0 0,0 9) {1,2} │ LINESTRING(0 9,9 0) {1,3} │ LINESTRING(9 0,0 0) (3 rows)
-- TIN -- SELECT path, ST_AsEWKT(geom) FROM ( SELECT (ST_DumpSegments(g.geom)).* FROM (SELECT 'TIN((( 0 0 0, 0 0 1, 0 1 0, 0 0 0 )), (( 0 0 0, 0 1 0, 1 1 0, 0 0 0 )) )'::geometry AS geom ) AS g ) j; path │ st_asewkt --------------------------------- {1,1,1} │ LINESTRING(0 0 0,0 0 1) {1,1,2} │ LINESTRING(0 0 1,0 1 0) {1,1,3} │ LINESTRING(0 1 0,0 0 0) {2,1,1} │ LINESTRING(0 0 0,0 1 0) {2,1,2} │ LINESTRING(0 1 0,1 1 0) {2,1,3} │ LINESTRING(1 1 0,0 0 0) (6 rows)