• 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?

Cloud VPS
0 głosów
2,336 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,260 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,260 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,590 wizyt
0 głosów
2 odpowiedzi 1,041 wizyt
pytanie zadane 9 marca 2017 w SQL, bazy danych przez TeslaX93 Gaduła (3,600 p.)
+2 głosów
1 odpowiedź 445 wizyt
pytanie zadane 22 października 2021 w SQL, bazy danych przez p4wix Obywatel (1,040 p.)

93,460 zapytań

142,454 odpowiedzi

322,724 komentarzy

62,837 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

Kursy INF.02 i INF.03
...