RipeX Skrevet 29. oktober 2009 Del Skrevet 29. oktober 2009 Hei, Jeg har ikke så mye peiling på optimalisering av MySQL. Så da lurer jeg på om dere kan fortelle med hva jeg kan gjøre for å forbedre koden nedenfor? Er sikkert mye å ta tak i. $new_limit = time()-(60*60*24*14); SELECT g.id, g.title, g.slug, g.thumbnail_url, g.time, (SELECT avg(value) FROM ratings WHERE gid = g.id) AS rating, (SELECT count(id) FROM plays WHERE time > '$new_limit' AND time < 'time() AND gid = g.id) AS plays, ((SELECT avg(value) FROM ratings WHERE gid = g.id) * (SELECT count(id) FROM plays WHERE time > '$new_limit' AND time < 'time()' AND gid = g.id)) AS overall FROM games g GROUP BY g.id ORDER BY overall DESC LIMIT 10 Siden min som er "hostet" hos ServeTheWorld klarer denne ganske greit, men den andre siden min på HostGator har ikke sjangs å klare denne. Lenke til kommentar
siDDis Skrevet 29. oktober 2009 Del Skrevet 29. oktober 2009 Ganske enkelt....du bruker avg og count altfor mange gonger. avg og count vil utføre full table scan for kvar gong dei brukes. Har du mange rader så kan det ta vanvittig lang tid. Derfor anbefaler eg å cache data, å levere den type data i realtime for fleire brukerar krever vanvittige ressurser uansett. Lenke til kommentar
RipeX Skrevet 30. oktober 2009 Forfatter Del Skrevet 30. oktober 2009 Ah, skjønner. Takk for svar! Lenke til kommentar
Anbefalte innlegg
Opprett en konto eller logg inn for å kommentere
Du må være et medlem for å kunne skrive en kommentar
Opprett konto
Det er enkelt å melde seg inn for å starte en ny konto!
Start en kontoLogg inn
Har du allerede en konto? Logg inn her.
Logg inn nå