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)

7/10/2012