ST_PointN

定義

ST_PointN は、ST_LineString と整数インデックスを入力として、ST_LineString のパスにある、n 番目の頂点のポイントを返します。

構文

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

戻り値のタイプ

ST_Point

各行を一意に識別する gid 列と、ln1 ST_LineString 列を持つ pointn_test テーブルを作成します。INSERT ステートメントは、2 つのラインストリング値を挿入します。最初のラインストリングには Z 座標またはメジャー値がありませんが、2 番目のラインストリングには両方あります。

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 列と 2 番目の頂点をリストします。最初の行には Z 座標またはメジャー値のない ST_Point、2 番目の行には Z 座標とメジャー値がある ST_Point がリストされます。ST_PointN 関数には、ソースのラインストリングに存在していれば、Z 座標またはメジャー値も含まれます。

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