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

Функции для работы с 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 с заданной точностью, которые попадают внутрь и пересекают границы заданного прямоугольника, фактически это 2D сетка, преобразованная в массив.

Синтаксис

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.
примечание

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

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

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

Функция выбрасывает исключение, если результирующий массив превышает 10'000'000 элементов.

Пример

Запрос:

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

Результат:

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