Перейти к основному содержанию
Перейти к основному содержанию

Функции для работы с геометрией

Геометрия

Функции для работы с геометрией позволяют вычислять периметр и площадь для геометрических типов, таких как POLYGON, LINESTRING, MULTIPOLYGON, MULTILINESTRING, RING и POINT. Используйте геометрические объекты в типе данных Geometry. Если входное значение равно NULL, все приведённые ниже функции вернут 0.

perimeterCartesian

Вычисляет периметр заданного объекта типа Geometry в декартовой (плоской) системе координат.

Синтаксис

perimeterCartesian(geom)

Аргументы

  • geom — объект типа Geometry. Geometry.

Возвращаемые значения

  • Number — периметр объекта в единицах системы координат. Float64.

Пример

CREATE TABLE IF NOT EXISTS geo_dst (geom Geometry) ENGINE = Memory();
INSERT INTO geo_dst SELECT readWKT('POLYGON((0 0,1 0,1 1,0 1,0 0))');
SELECT perimeterCartesian(geom) FROM geo_dst;
┌─perimeterCartesian(geom)─┐
│ 4.0                      │
└──────────────────────────┘

areaCartesian

Вычисляет площадь заданного объекта Geometry в декартовой системе координат.

Синтаксис

areaCartesian(geom)

Аргументы

  • geom — объект типа Geometry. Geometry.

Возвращаемые значения

  • Number — площадь объекта в единицах координатной системы. Float64.

Пример

CREATE TABLE IF NOT EXISTS geo_dst (geom Geometry) ENGINE = Memory();
INSERT INTO geo_dst SELECT readWKT('POLYGON((0 0,1 0,1 1,0 1,0 0))');
SELECT areaCartesian(geom) FROM geo_dst;
┌─areaCartesian(geom)─┐
│ -1                  │
└─────────────────────┘

perimeterSpherical

Вычисляет периметр объекта Geometry на поверхности сферы.

Синтаксис

perimeterSpherical(geom)

Аргументы

  • geom — объект Geometry. Geometry.

Возвращаемые значения

  • Число — периметр. Float64.

Пример

CREATE TABLE IF NOT EXISTS geo_dst (geom Geometry) ENGINE = Memory();
INSERT INTO geo_dst SELECT readWKT('LINESTRING(0 0,1 0,1 1,0 1,0 0)');
SELECT perimeterSpherical(geom) FROM geo_dst;
┌─perimeterSpherical(geom)─┐
│ 0                        │
└──────────────────────────┘

areaSpherical

Вычисляет площадь объекта типа Geometry на поверхности сферы.

Синтаксис

areaSpherical(geom)

Аргументы

  • geom — объект типа Geometry. Geometry.

Возвращаемые значения

  • Number — площадь. Float64.

Пример

CREATE TABLE IF NOT EXISTS geo_dst (geom Geometry) ENGINE = Memory();
INSERT INTO geo_dst SELECT readWKT('POLYGON((0 0,1 0,1 1,0 1,0 0))');
SELECT areaSpherical(geom) FROM geo_dst;
┌─areaSpherical(geom)────┐
│ -0.0003046096848622019 │
└────────────────────────┘