ST_PointN
Определение
Функция ST_PointN принимает ST_LineString и целочисленный индекс и возвращает точку, являющуюся n-й вершиной в пути ST_LineString.
Синтаксис
sde.st_pointn (ln1 sde.st_linestring, index integer)
Тип возврата
ST_Point
Пример
Таблица pointn_test создается со столбцом gid, который уникально определяет каждую строку, и столбцом ln1 ST_LineString, в котором хранятся строки linestring. Инструкция INSERT вставляет два значения linestring. У первой строки linestring нет z-координат или измерений, а у второй есть и то, и другое.
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)
);
Запрос возвращает столбец gid и вторую вершину каждой строки linestring. Первая строка приводит к получению ST_Point без z-координаты или измерения, а вторая строка приводит к получению ST_Point с z-координатой и измерением. Функция ST_PointN также будет содержать z-координату или измерение, если они есть в исходной строке linestring.
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)