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

0 głosów
163 wizyt
pytanie zadane 10 grudnia 2018 w SQL, bazy danych przez k222 Nałogowiec (27,010 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 Maniak (70,020 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 (27,010 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 Maniak (70,020 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 (27,010 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 662 wizyt
0 głosów
2 odpowiedzi 138 wizyt
pytanie zadane 9 marca 2017 w SQL, bazy danych przez TeslaX93 Gaduła (3,240 p.)
0 głosów
2 odpowiedzi 71 wizyt
Porady nie od parady
Zadając pytanie postaraj się o szczegółowe opisanie problemu oraz udostępnienie wszystkich istotnych informacji (kody źródłowe, zrzuty ekranu itp.).Opisanie problemu

65,753 zapytań

112,388 odpowiedzi

237,308 komentarzy

46,699 pasjonatów

Przeglądających: 217
Pasjonatów: 13 Gości: 204

Motyw:

Akcja Pajacyk

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

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...