geo_line_length()
Область применения: ✅Microsoft Fabric✅Azure Data Explorer✅Azure Monitor✅Microsoft Sentinel
Вычисляет общую длину линии или многострочный на Земле.
Синтаксис
geo_line_length(
lineString)
Дополнительные сведения о соглашениях синтаксиса.
Параметры
Имя (название) | Type | Обязательно | Описание |
---|---|---|---|
lineString | dynamic |
✔️ | LineString или MultiLineString в формате GeoJSON. |
Возвраты
Общая длина линии или многострочный, в метрах, на Земле. Если строка или многострочный объект недопустим, запрос создаст результат NULL.
Примечание.
- Геопространственные координаты интерпретируются как представленные эталонной системой координат WGS-84 .
- Геостатический datum , используемый для измерения расстояния на Земле является сферой. Границы линии — геодесик на сфере.
- Если границы линии ввода являются прямыми декартовыми линиями, рассмотрите возможность использования geo_line_densify() для преобразования планарных ребер в геодесетики.
- Если входные данные являются многострочного и содержат несколько строк, результатом будет общая длина объединения линий.
Определение и ограничения LineString
dynamic({"type": "LineString","координаты": [[lng_1,lat_1], [lng_2,lat_2], ..., [lng_N,lat_N]]})
dynamic({"type": "MultiLineString","координаты": [[line_1, line_2, ..., line_N]})
- Массив координат LineString должен содержать не менее двух записей.
- Координаты [долгота, широта] должны быть допустимыми, где долгота является реальным числом в диапазоне [-180, +180] и широта является реальным числом в диапазоне [-90, +90].
- Длина края должна быть меньше 180 градусов. Будет выбран самый короткий край между двумя вершинами.
Примеры
В следующем примере вычисляется общая длина линии в метрах.
let line = dynamic({"type":"LineString","coordinates":[[-73.95807266235352,40.800426144169315],[-73.94966125488281,40.79691751000055],[-73.97317886352539,40.764486356930334]]});
print length = geo_line_length(line)
Выходные данные
length |
---|
4922.48016992081 |
В следующем примере вычисляется общая многостроальная длина в метрах.
let line = dynamic({"type":"MultiLineString","coordinates":[[[-73.95798683166502,40.800556090021466],[-73.98193359375,40.76819171855746]],[[-73.94940376281738,40.79691751000055],[-73.97317886352539,40.76435634049001]]]});
print length = geo_line_length(line)
Выходные данные
length |
---|
8262.24339753741 |
В следующем примере возвращается значение True из-за недопустимой строки.
print is_bad_line = isnull(geo_line_length(dynamic({"type":"LineString","coordinates":[[1, 1]]})))
Выходные данные
is_bad_line |
---|
Истина |