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

#1111 - Invalid use of group function

VPS Starter Arubacloud
0 głosów
111 wizyt
pytanie zadane 8 lutego 2020 w SQL, bazy danych przez manager96 Bywalec (2,050 p.)

Hejka mam pytanie jak w temacie, jak radzić sobie z błędem 1111, jest to jedyny błąd który wyskakuje mi notorycznie z którym nie umiem sobie poradzić, np występuje w poniższym przykładzie w którym chce wyświetlić sumę wartości dla trzeciego kwartału:

SELECT dokumenty.id_dokumentu, dokumenty.data, SUM(pozycje.wart)
FROM dokumenty
LEFT JOIN pozycje ON (pozycje.id_dokumentu = dokumenty.id_dokumentu)
WHERE MONTH(dokumenty.data) = 07 OR 08 OR 09
GROUP BY dokumenty.id_dokumentu, dokumenty.data, SUM(pozycje.wart)

Co powinienem zrobić żeby zapytanie zadziałało poprawnie, błąd pojawia się podczas użycia GROUP BY, zawsze

1 odpowiedź

0 głosów
odpowiedź 8 lutego 2020 przez adrian17 Ekspert (346,900 p.)
wybrane 7 marca 2020 przez manager96
 
Najlepsza

GROUP BY dokumenty.id_dokumentu, dokumenty.data, SUM(pozycje.wart)

SUM to jest suma wartości po agregacji. Ale tutaj próbujesz agregować po sumie, co odwraca przyczynę i skutek :P Także sugeruję przemyśleć, po czym chcesz grupować.

A swoją drogą:

WHERE MONTH(dokumenty.data) = 07 OR 08 OR 09

Mam wrażenie, że ten OR też nie zrobi tego co chcesz. Zamiast tego, użyj operatora `in`

Podobne pytania

0 głosów
1 odpowiedź 157 wizyt
pytanie zadane 23 stycznia 2023 w C i C++ przez Marcinuq Użytkownik (690 p.)
0 głosów
1 odpowiedź 794 wizyt
0 głosów
1 odpowiedź 233 wizyt
pytanie zadane 4 maja 2018 w C i C++ przez Prime_Bull Obywatel (1,820 p.)

92,763 zapytań

141,687 odpowiedzi

320,499 komentarzy

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

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!

...