ST_StartPoint
Определение
ST_StartPoint возвращает первую точку линии linestring.
Синтаксис
sde.st_startpoint (ln1 sde.st_geometry)
Тип возврата
ST_Point
Примеры
Таблица startpoint_test создается с целочисленным столбцом gid, который уникально определяет строки таблицы, и столбцом ln1 ST_LineString, в котором хранятся строки linestring.
CREATE TABLE startpoint_test (gid integer, ln1 sde.st_geometry);
Инструкция INSERT вставляет три строки ST_LineStrings в столбец ln1. У первой строки ST_LineString нет z-координат или измерений, а у второй есть и то, и другое.
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)
);
Функция ST_StartPoint получает первую точку каждой строки ST_LineString. У первой точки в списке нет z-координаты или измерения, а у второй есть и то, и другое, так как у исходной строки linestring есть z-координаты и измерения.
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)
9/11/2013