Вычисление медианы из 3 столбцов в таблице BigQuery

0

Вопрос

Я пытаюсь построить запрос для вычисления медианы значений 3 столбцов. Моя таблица выглядит так, как показано ниже,

Предмет Колонка 1 Колонка 2 Колонка 3
A 10 12 4
B 5 14 20
C 15 5 4

Я хочу иметь возможность выводить,

Предмет Колонка 1 Колонка 2 Колонка 3 Срединный
A 10 12 4 10
B 5 14 20 14
C 15 5 4 5

Я попробовал percentile_cont (), но, похоже, это только для значений в одном столбце. Как мне этого добиться?

google-bigquery median
2021-11-23 17:41:55
2

Лучший ответ

2

Рассмотрим следующий подход

select *, 
  ( select distinct percentile_disc(col, 0.5) over() 
    from unnest([Column1, Column2, Column3]) as col
  ) AS Median
from your_table       

если применить к образцам данных в вашем вопросе - вывод будет

enter image description here

2021-11-23 22:50:39

Спасибо!! Это сработало!
pear_geepee
0

Вы пробовали это:

select Col1, Col2, Col3, 
       PERCENTILE_CONT([Col1, Col2, Col3], 0.5) OVER() AS Median
from   tableName
2021-11-23 18:06:09

Да, но это приводит к ошибке, так как нет совпадающей подписи для аналитической функции PERCENTILE_CONT для типов аргументов: МАССИВ<FLOAT64>, FLOAT64. Поддерживаемые подписи: ПРОЦЕНТИЛЬ_КОНТ(FLOAT64, FLOAT64); ПРОЦЕНТИЛЬ_КОНТ(ЧИСЛОВОЙ, ЧИСЛОВОЙ); ПРОЦЕНТИЛЬ_КОНТ(ЧИСЛОВОЙ, ЧИСЛОВОЙ) в [5:3]
pear_geepee

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................