定義
ST_Length は、ライン ストリングまたはマルチライン ストリングの長さを返します。
構文
Oracle および PostgreSQL
sde.st_length (line1 sde.st_geometry) sde.st_length (multiline1 sde.st_geometry)
SQLite
st_length (line1 geometryblob) st_length (multiline1 geometryblob) st_length (line1 geometryblob, unit_name text) st_length (multiline1 geometryblob, unit_name text)
サポートされる単位名の一覧については、「ST_Distance」をご参照ください。
戻り値のタイプ
Double precision
例
国内の水路に生息する鮭の移動パターンを調査している生態学者は、国内のすべての水路と河川の長さを知りたいと考えています。
テーブルに格納された各水路と河川を識別する ID と name 列を持つ waterways テーブルを作成します。水路と河川は複数のラインストリングの集合であることが多いため、water 列はマルチラインストリングです。
SELECT クエリは、水路の名前と、ST_Length 関数によって出力されたその水路の長さを返します。Oracle および PostgreSQL の場合、単位は座標系で使用されているものになります。SQLite の場合、単位としてキロメートルが指定されます。
Oracle
CREATE TABLE waterways (
oid integer,
name varchar(128),
water sde.st_geometry
);
INSERT INTO waterways (oid, name, water) VALUES (
1111,
'Genesee',
sde.st_multilinestring ('multilinestring ((33 2, 34 3, 35 6),
(28 4, 29 5, 31 8, 43 12), (39 3, 37 4, 36 7))', 4326)
);
SELECT name, sde.st_length (water) "Length"
FROM WATERWAYS;
NAME Length
Genesee 27.6437123
PostgreSQL
CREATE TABLE waterways (
oid serial,
name varchar(128),
water sde.st_geometry
);
INSERT INTO waterways (name, water) VALUES (
'Genesee',
sde.st_multilinestring ('multilinestring ((33 2, 34 3, 35 6),
(28 4, 29 5, 31 8, 43 12), (39 3, 37 4, 36 7))', 4326)
);
SELECT name AS "Watershed Name",
sde.st_length (water) AS "Length"
FROM waterways;
Watershed Name | Length
Genesee | 27.6437123387202
SQLite
CREATE TABLE waterways (
oid integer primary key autoincrement not null,
name text(128)
);
SELECT AddGeometryColumn (
NULL,
'waterways',
'water',
4326,
'multilinestring',
'xy',
'null'
);
INSERT INTO waterways (name, water) VALUES (
'Genesee',
st_multilinestring ('multilinestring ((33 2, 34 3, 35 6),
(28 4, 29 5, 31 8, 43 12), (39 3, 37 4, 36 7))', 4326)
);
SELECT name AS "Watershed Name",
st_length (water, 'kilometer') AS "Length"
FROM waterways1;
Watershed Name Length
Genesee 3047.75515002795