Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Optymalizacja zapytania SQL
neo1986kk
post 1.06.2017, 14:09:40
Post #1





Grupa: Zarejestrowani
Postów: 561
Pomógł: 3
Dołączył: 2.02.2009

Ostrzeżenie: (0%)
-----


Witam mam 3 tabele, z których potrzebuję wyciągnąć dane

Produkty - z niej potrzebuję ID produktu (w bazie 6000 rekordów)
Dokumenty - dokumenty do produktów - potrzebuję status dokumentu ( w bazie ok 5000 rekordów)
Zamówienia - tutaj też potrzebuje tylko ID zamówienia jeśli istnieje do danego produktu ( w bazie około 15 000 rekordów)

  1. SELECT produkty.id, dokumenty.STATUS, zamowienia.id FROM produkty
  2. LEFT JOIN dokumenty ON dokumenty.product=produkty.id
  3. LEFT JOIN zamowienia z ON produkty.id=zamowienia.product
  4. WHERE (zamowienia.id=NULL OR dokumenty.STATUS!='ACCEPTED') GROUP BY produkty.id


Pokrótce: Wyciągam tylko te produkty, które nie mają zamówienia lub dokument nie jest zaakceptowany
Zapytanie działa w miarę poprawnie, jest to lekkich poprawek bo dokumentów moze być więcej niż jeden i trzeba sprawdzić czy ostatni jest zaakceptowany, ale ważniejszym problemem jest to, że
takie zapytanie SQL robi w okolo 2 minuty. Macie jakieś pomysły jak to zoptymalizować? Pozdrawiam.
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 25.07.2025 - 01:54