• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Jak w SQL od każdej wartości danej kolumny odjąć wartość średnią kolumny?

Object Storage Arubacloud
0 głosów
1,804 wizyt
pytanie zadane 10 grudnia 2018 w SQL, bazy danych przez k222 Nałogowiec (30,150 p.)

Cześć, mam do napisania zapytanie, które mnie na chwilę przystopowało, bo powiedzmy że mamy tabelę TABELA, gdzie mamy kolumny ID, CENA i chcemy jako wynik zapytania otrzymać tabelę: ID, CENA, CENA - średnia(CENA), czyli ostatnia kolumna ma być takim jakby odchyleniem od średniej i moje pytanie jak to zrobić?

Ja na razie próbowałem użyć INNER JOINa żeby połączyć tabelę z samą sobą, coś w stylu:

select t1.ID, t1.Cena, t1.Cena - avg(t2.Cena) 
from Tabela as t1
inner join Tabela as t2
    on t1.ID = t2.ID

od razu mówię, że muszę to zrobić używając rzeczy typu joiny, group by, wersja z with lub selectem w selec'cie nie przejdzie (tamte w sumie umiałbym napisać, tylko tutaj mam problem z dołączeniem tej wartości średniej kolumny)

2 odpowiedzi

+1 głos
odpowiedź 10 grudnia 2018 przez mbabane Szeryf (79,280 p.)

Inaczej niż wykorzystując do tego podzapytania to chyba się nie da, w końcu trzeba jakoś tę wartość otrzymać:

SELECT value, mean.v a,  value - mean.v diff, id
FROM tbl, (select avg(value) as v from tbl) as mean

tbl to:

tbl
id int
value int
komentarz 10 grudnia 2018 przez k222 Nałogowiec (30,150 p.)
dzięki, chociaż jakoś się musi dać - jeszcze nie wiem jak, bo jedno z ćwiczeń z SQLa o takiej treści jest do wykonania z podzapytaniem i bez niego, i tą pierwszą opcję zrobiłem tak jak ty pokazałeś, a odnośnie tej drugiej jeszcze się zastanawiam
komentarz 10 grudnia 2018 przez mbabane Szeryf (79,280 p.)
to nie wiem, może jakiś bardziej złożony GROUP BY, bo rozumiem że nie masz jakiś sugestii w tym ćwiczeniu?
0 głosów
odpowiedź 11 grudnia 2018 przez k222 Nałogowiec (30,150 p.)

Jakby się to komuś miało przydać, to w takim przypadku jak w temacie, właśnie pomocny może być CROSS JOIN

select t1.ID, t1.Cena, t1.Cena - avg(t2.Cena)
from Tabela as t1
cross join Tabela as t2
group by t1.ID, t1.Cena

 

Podobne pytania

0 głosów
3 odpowiedzi 3,134 wizyt
0 głosów
2 odpowiedzi 774 wizyt
pytanie zadane 9 marca 2017 w SQL, bazy danych przez TeslaX93 Gaduła (3,600 p.)
+2 głosów
1 odpowiedź 291 wizyt
pytanie zadane 22 października 2021 w SQL, bazy danych przez p4wix Obywatel (1,040 p.)

92,568 zapytań

141,422 odpowiedzi

319,641 komentarzy

61,957 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...