Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL]Rozbudowane zapytanie mysql + sumowanie rekordów
Forum PHP.pl > Forum > Przedszkole
miras
Witam, mam następujący problem: mam 2 tabele - w jednej id_zamowienia, a w drugiej produkty, które należą do tego zamówienia, mam takie zapytanie, które przypisuje ID zamówienia do produktów i ich cen, potrzbeuję zrobić takie zapytanie, które wyświetli mi ID_zamówienia i zsumowaną cenę wszystkich produktów, które należą do tego zamówienia.

mam tyle:

  1. SELECT * FROM orderr JOIN order_product ON orderr.id = order_product.id_order JOIN product ON order_product.id_product = product.id



@@ edit, zapomniałem o tabelce z cenami produktów, już pobiera mi te dane, teraz potrzebuję tylko zrobić, żeby sumowało mi te dane a nie wyświetlało rekordy jeden pod drugim..
nospor
GROUP BY oraz SUM
miras
Tyle już wygooglowałem, ale za cholerę nie moge użyć tego SUM w moim zapytaniu, czy kompletnie źle zacząłem budować te zapytanie?

Ok, już mam:


  1. SELECT orderr.id, SUM( product.price * order_product.quantity )
  2. FROM orderr
  3. JOIN order_product ON orderr.id = order_product.id_order
  4. JOIN product ON order_product.id_product = product.id


tak wygląda moje zapytanie, wszystko działa, potrzebuję jeszcze tylko dodać warunek

taki:

  1. WHERE SUM( product.price * order_product.quantity ) >1000


jak to zrobić ?
in5ane
Kod
SELECT
    o.id AS order,
    SUM(p.price * op.quantity) AS price
FROM
    order o
INNER JOIN order_product op ON op.id_order = o.id
INNER JOIN product p ON p.id = op.id_product
WHERE
    price > 1000
Może coś takiego zadziała?

@edit: nie powinno się używać nazwy tabeli order tongue.gif
miras
Niestety nie działa..

obecny kod:

  1. SELECT orderr.id, SUM( product.price * order_product.quantity ) AS cena
  2. FROM orderr
  3. JOIN order_product ON orderr.id = order_product.id_order
  4. JOIN product ON order_product.id_product = product.id
  5. GROUP BY orderr.id


kolumna cena normalnie jest, działa elegancko, ale jak zrobię tak:


  1. SELECT orderr.id, SUM( product.price * order_product.quantity ) AS cena
  2. FROM orderr
  3. JOIN order_product ON orderr.id = order_product.id_order
  4. JOIN product ON order_product.id_product = product.id
  5. GROUP BY orderr.id
  6. WHERE cena>1000



to mi wywala:


Something is wrong in your syntax obok 'WHERE cena>1000 LIMIT 0, 30' w linii 6
nospor
Zajrzyj do manuala mysql i zobacz jaka jest prawidlowa kolejnosc poszczegolnych rzeczy w zapytaniu.
miras
No dobrze, ale jak zapytanie jest tak zbudowane:

  1. SELECT orderr.id, SUM( product.price * order_product.quantity ) AS cena
  2. FROM orderr
  3. JOIN order_product ON orderr.id = order_product.id_order
  4. JOIN product ON order_product.id_product = product.id
  5. WHERE cena>1000
  6. GROUP BY orderr.id
  7.  


to błąd: #1054 - Nieznana kolumna 'cena' w where clause
nospor
Kominikat wyraznie mowi: nie masz kolumny cena
miras
no ok, rozumiem, myślałem, że to 'robi' za tą kolumnę: SUM( product.price * order_product.quantity ) AS cena

w takim razie jak mam to zrobić?
_Borys_
Usuń WHERE cena > 1000
Dodaj na końcu HAVING cena > 1000
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.