ST_PointN
Definition
ST_PointN akzeptiert ein ST_LineString-Objekt und einen ganzzahligen Index und gibt den Punkt zurück, der den n-ten Stützpunkt im Pfad des ST_LineString-Objekts darstellt.
Syntax
sde.st_pointn (ln1 sde.st_linestring, index integer)
Rückgabetyp
ST_Point
Beispiel
Die Tabelle "pointn_test" wird mit der Spalte "gid", durch die die einzelnen Zeilen eindeutig gekennzeichnet werden, und der Spalte "pt1" vom Typ ST_LineString erstellt. Mit der INSERT-Anweisung werden zwei Linestring-Werte in die Tabelle eingefügt. Der erste Linestring enthält weder Z-Koordinaten noch Messwerte, der zweite Linestring dagegen beides.
Oracle
CREATE TABLE pointn_test (gid integer, ln1 sde.st_geometry); INSERT INTO POINTN_TEST VALUES ( 1, sde.st_linefromtext ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 0) ); INSERT INTO POINTN_TEST VALUES ( 2, sde.st_linefromtext ('linestring zm(10.02 20.01 5.0 7.0, 23.73 21.92 6.5 7.1, 30.10 40.23 6.9 7.2)', 0) );
PostgreSQL
CREATE TABLE pointn_test (gid integer, ln1 sde.st_geometry); INSERT INTO pointn_test VALUES ( 1, sde.st_linestring ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 0) ); INSERT INTO pointn_test VALUES ( 2, sde.st_linestring ('linestring zm(10.02 20.01 5.0 7.0, 23.73 21.92 6.5 7.1, 30.10 40.23 6.9 7.2)', 0) );
Die Abfrage listet die Spalte "gid" und den zweiten Stützpunkt jedes Linestring auf. Die erste Zeile ergibt ein ST_Point-Objekt ohne Z-Koordinate oder Messwert. Die zweite Zeile ergibt dagegen ein ST_Point-Objekt mit Z-Koordinate und Messwert. Die Funktion ST_PointN berücksichtigt die Z-Koordinate oder den Messwert, wenn diese im Quell-Linestring enthalten sind.
Oracle
SELECT gid, sde.st_astext (sde.st_pointn (ln1, 2)) The_2ndvertex FROM POINTN_TEST; GID The_2ndvertex 1 POINT (23.73 21.92) 2 POINT ZM (23.73 21.92 6.5 7.1)
PostgreSQL
SELECT gid, sde.st_astext (sde.st_pointn (ln1, 2)) AS The_2ndvertex FROM pointn_test; gid the_2ndvertex 1 POINT (23.73 21.92) 2 POINT ZM (23.73 21.92 6.5 7.1)