Bir BigQuery tablosunda 3 sütunun medyanını hesaplama

0

Soru

3 Sütun değerinin medyanını hesaplamak için bir sorgu oluşturmaya çalışıyorum. Masam aşağıdaki gibi görünüyor,

Öğe Sütun 1 Sütun 2 Sütun 3
A 10 12 4
B 5 14 20
C 15 5 4

Çıktı alabilmek istiyorum,

Öğe Sütun 1 Sütun 2 Sütun 3 Medyan
A 10 12 4 10
B 5 14 20 14
C 15 5 4 5

Persentile_cont () denedim ama bu sadece tek bir sütundaki değerler için görünüyor. Bunu nasıl elde edebilirim?

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

En iyi cevabı

2

Aşağıdaki yaklaşımı göz önünde bulundurun

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

sorunuzdaki örnek verilere uygulanırsa-çıktı

enter image description here

2021-11-23 22:50:39

Teşekkürler!! Bu işe yaradı!
pear_geepee
0

Bunu denedin mi:

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

Evet, ancak bu, argüman türleri için analitik işlev PERCENTİLE_CONT için eşleşen imza olarak hata veriyor: ARRAY<FLOAT64>, FLOAT64. Desteklenen imzalar: PERSENTİLE_CONT(FLOAT64, FLOAT64); PERSENTİLE_CONT(SAYISAL, SAYISAL); PERSENTİLE_CONT (BÜYÜK sayı, büyük sayı) [5:3]
pear_geepee

Diğer dillerde

Bu sayfa diğer dillerde

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................