ST_PointN

Définition

ST_PointN prend un ST_LineString et un index de nombre entier, et renvoie un point qui est le énième sommet dans le chemin du ST_LineString.

Syntaxe

sde.st_pointn (ln1 sde.st_linestring, index integer)

Type de retour

ST_Point

Exemple

La table pointn_test est créée avec la colonne gid qui identifie chaque ligne de façon unique, et la colonne ln1 ST_LineString. L'instruction INSERT insère deux valeurs linestring. Le premier objet linestring ne possède pas de coordonnée z ni de mesure, alors que le deuxième objet linestring possède les deux.

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)
);

La requête répertorie la colonne gid et le deuxième sommet de chaque linestring. Le premier enregistrement résulte en un objet ST_Point sans coordonnée z ni mesure, tandis que le deuxième enregistrement résulte en un objet ST_Point avec une coordonnée z et une mesure. La fonction ST_PointN inclura également une coordonnée z ou une valeur de mesure, si elles existent dans l'objet linestring source.

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)

3/6/2012