Ein ST_StartPoint
Definition
ST_StartPoint gibt den ersten Punkt eines Linestrings zurück.
Syntax
sde.st_startpoint (ln1 sde.st_geometry)
Rückgabetyp
ST_Point
Beispiele
Die Tabelle "startpoint_test" wird mit der ganzzahligen Spalte "gid", durch die die einzelnen Tabellenzeilen eindeutig gekennzeichnet werden, und der Spalte "pt1" vom Typ ST_LineString erstellt.
CREATE TABLE startpoint_test (gid integer, ln1 sde.st_geometry);
Mit der INSERT-Anweisung werden die ST_LineString-Werte in die Spalte "ln1" eingefügt. Der erste ST_LineString-Eintrag enthält weder Z-Koordinaten noch Messwerte, der zweite ST_LineString_Eintrag dagegen beides.
Oracle
INSERT INTO STARTPOINT_TEST VALUES ( 1, sde.st_linefromtext ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 0) ); INSERT INTO STARTPOINT_TEST VALUES ( 2, sde.st_linefromtext ('linestring zm(10.02 20.01 5 7, 23.73 21.92 6.5 7.1, 30.10 40.23 6.9 7.2)', 0) );
PostgreSQL
INSERT INTO startpoint_test VALUES ( 1, sde.st_linestring ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 0) ); INSERT INTO startpoint_test VALUES ( 2, sde.st_linestring ('linestring zm(10.02 20.01 5 7, 23.73 21.92 6.5 7.1, 30.10 40.23 6.9 7.2)', 0) );
Funktion ST_StartPoint extrahiert den ersten Punkt jedes ST_LineString-Eintrags. Der Punkt in der Liste enthält weder Z-Koordinaten noch Messwerte, der zweite Punkt enthält dagegen beides, weil diese im Quell-Linestring enthalten sind.
Oracle
SELECT gid, sde.st_astext (sde.st_startpoint (ln1)) Startpoint FROM STARTPOINT_TEST; GID Startpoint 1 POINT (10.02000000 20.01000000) 2 POINT ZM (10.02000000 20.01000000 5.00000000 7.00000000)
PostgreSQL
SELECT gid, sde.st_astext (sde.st_startpoint (ln1)) AS Startpoint FROM startpoint_test; gid startpoint 1 POINT (10.02000000 20.01000000) 2 POINT ZM (10.02000000 20.01000000 5.00000000 7.00000000)