Определение
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.
Тип возврата
Двойная точность
Пример:
Местный эколог, изучающий особенности миграции популяции лосося в водоемах страны, хочет получить длину всех ручьев и речных систем в стране.
Создается таблица waterways со столбцами ID и name, которые определяют все ручьи и реки, хранимые в таблице. Столбец water имеет тип multilinestring, так как ручьи и реки часто являются объединениями нескольких элементов типа linestring.
Запрос 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