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

Функции для работы с Geohash

Geohash

Geohash — это система геокодирования, которая разбивает поверхность Земли на ячейки в виде сетки и кодирует каждую ячейку в короткую строку из букв и цифр. Это иерархическая структура данных, поэтому чем длиннее строка geohash, тем более точным будет географическое местоположение.

Если вам нужно вручную преобразовать географические координаты в строки geohash, вы можете использовать geohash.org.

geohashEncode

Кодирует широту и долготу в строку формата geohash.

Синтаксис

geohashEncode(longitude, latitude, [precision])

Входные значения

  • longitude — Долгота координаты, которую нужно закодировать. Число с плавающей точкой в диапазоне [-180°, 180°]. Float.
  • latitude — Широта координаты, которую нужно закодировать. Число с плавающей точкой в диапазоне [-90°, 90°]. Float.
  • precision (необязательный) — Длина результирующей закодированной строки. По умолчанию — 12. Целое число в диапазоне [1, 12]. Int8.
Примечание
  • Все параметры координат должны быть одного типа: либо Float32, либо Float64.
  • Для параметра precision любое значение меньше 1 или больше 12 автоматически приводится к 12.

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

  • Буквенно-цифровая строка закодированной координаты (используется модифицированная версия алфавита base32-кодирования). String.

Пример

Запрос:

SELECT geohashEncode(-5.60302734375, 42.593994140625, 0) AS res;

Результат:

┌─res──────────┐
│ ezs42d000000 │
└──────────────┘

geohashDecode

Декодирует любую строку, закодированную в формате geohash, в координаты широты и долготы.

Синтаксис

geohashDecode(hash_str)

Входные значения

  • hash_str — строка в кодировке Geohash.

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

  • Кортеж (longitude, latitude) из значений типа Float64 для долготы и широты. Tuple(Float64)

Пример

SELECT geohashDecode('ezs42') AS res;
┌─res─────────────────────────────┐
│ (-5.60302734375,42.60498046875) │
└─────────────────────────────────┘

geohashesInBox

Возвращает массив строк, закодированных в geohash с заданной точностью, которые находятся внутри и пересекают границы указанного прямоугольника, по сути представляя собой двумерную сетку, свернутую в массив.

Синтаксис

geohashesInBox(longitude_min, latitude_min, longitude_max, latitude_max, precision)

Аргументы

  • longitude_min — Минимальная долгота. Диапазон: [-180°, 180°]. Float.
  • latitude_min — Минимальная широта. Диапазон: [-90°, 90°]. Float.
  • longitude_max — Максимальная долгота. Диапазон: [-180°, 180°]. Float.
  • latitude_max — Максимальная широта. Диапазон: [-90°, 90°]. Float.
  • precision — Точность geohash-кода. Диапазон: [1, 12]. UInt8.

:::note
Все параметры координат должны быть одного типа: либо Float32, либо Float64. :::

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

  • Массив строк геохеш-боксов длиной precision, покрывающих указанную область; на порядок элементов полагаться не следует. Array(String).
  • [] — Пустой массив, если минимальные значения широты и долготы не меньше соответствующих максимальных значений.

:::note
Функция генерирует исключение, если результирующий массив содержит более 10'000'000 элементов. :::

Пример

Запрос:

SELECT geohashesInBox(24.48, 40.56, 24.785, 40.81, 4) AS thasos;

Результат:

┌─thasos──────────────────────────────────────┐
│ ['sx1q','sx1r','sx32','sx1w','sx1x','sx38'] │
└─────────────────────────────────────────────┘