ST_EndPoint
定義
ST_EndPoint は、ラインストリングの最後のポイントを返します。
構文
Oracle および PostgreSQL
sde.st_endpoint (line1 sde.st_geometry)
SQLite
st_endpoint (line1 geometryblob)
戻り値のタイプ
ST_Point
例
endpoint_test テーブルは、各行を一意に識別する gid 整数列と、ラインストリングを格納する ln1 ST_LineString 列を持ちます。
INSERT ステートメントは、ラインストリングを endpoint_test テーブルに挿入します。最初のラインストリングには Z 座標またはメジャー値がありませんが、2 番目のラインストリングにはあります。
クエリは、gid 列と、ST_EndPoint 関数によって生成された ST_Point ジオメトリをリストします。
Oracle
--Create table and insert values.
CREATE TABLE endpoint_test (
gid integer,
ln1 sde.st_geometry
);
INSERT INTO ENDPOINT_TEST VALUES (
1,
sde.st_linefromtext ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 4326)
);
INSERT INTO ENDPOINT_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)', 4326)
);
--Find the end point of each line.
SELECT gid, sde.st_astext (sde.st_endpoint (ln1)) Endpoint
FROM ENDPOINT_TEST;
GID Endpoint
1 POINT (30.10 40.23)
2 POINT ZM (30.10 40.23 6.9 7.2)
PostgreSQL
--Create table and insert values.
CREATE TABLE endpoint_test (
gid integer,
ln1 sde.st_geometry
);
INSERT INTO endpoint_test VALUES (
1,
st_linestring ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 4326)
);
INSERT INTO endpoint_test VALUES (
2,
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)', 4326)
);
--Find the end point of each line.
SELECT gid, st_astext (st_endpoint (ln1))
AS endpoint
FROM endpoint_test;
gid endpoint
1 POINT (30.10 40.23)
2 POINT ZM (30.10 40.23 6.9 7.2)
SQLite
--Create table, add geometry column, and insert values.
CREATE TABLE endpoint_test (
gid integer primary key autoincrement not null
);
SELECT AddGeometryColumn (
NULL,
'endpoint_test',
'ln1',
4326,
'linestringzm',
'xyzm',
'null'
);
INSERT INTO endpoint_test (ln1) VALUES (
st_linestring ('linestring (10.02 20.01, 23.73 21.92, 30.10 40.23)', 4326)
);
INSERT INTO endpoint_test (ln1) VALUES (
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)', 4326)
);
--Find the end point of each line.
SELECT gid, st_astext (st_endpoint (ln1))
AS "endpoint"
FROM endpoint_test;
gid endpoint
1 POINT (30.10000000 40.23000000)
2 POINT ZM (30.10000000 40.23000000 6.90000000 7.20000000)
関連トピック
5/25/2014