[Résolu] Optimisation script (requête SQL) - Version imprimable +- JeuWeb - Crée ton jeu par navigateur (https://jeuweb.org) +-- Forum : Discussions, Aide, Ressources... (https://jeuweb.org/forumdisplay.php?fid=38) +--- Forum : Programmation, infrastructure (https://jeuweb.org/forumdisplay.php?fid=51) +--- Sujet : [Résolu] Optimisation script (requête SQL) (/showthread.php?tid=2952) |
[Résolu] Optimisation script (requête SQL) - Joojo - 26-08-2008 Bonjour à tous avec ce jolie soleil du mois d'aout dont les rayons passent à travers ma fenêtre...quoi vous me croyez pas??.....Oui bon d'accord je ment... Bref je vais vous présenter quelques lignes de ma création qui fonctionnent. Celui-ci est utilisé à chaque déplacement du joueur pour faire revivre les monstres qui ont été tués par les joueurs. Chaque monstre a un temps de résurrection différent. Et comme je suis Satan en personne qui ne respecte pas la Bible PHP il y a une requête dans une boucle NAN PAS TAPER iffle: Sinon, petites explication: j'ai une table monstres qui contient tous les monstres différents existants (un de chaque en gros) qui contient les données de chacun. Et enfin une table map_monstres c'est à dire tous les monstres qui sont sur la map. Sur cette table chaque monstre à un id_id_monstre différent et un id_monstre pour aller chercher ses données dans la table monstres. J'ai crut qu'il y avait déjà eu des post ici mais je pense qu'ils ont dut partir avec le ménage du printemps. Bon voilà la bestiole: Code PHP :
Bref donc dans tout ça je voudrais si c'est possible ne faire qu'une requête pour faire revivre tous les monstres au lieu d'en faire une pour chacun. En gros je pense qu'il faut créer une sorte de tableau pour $vie_max_monstre, $exp_max_monstre, $date_actuelle, $id_id_monstre qui contiendrait les données de chaque monstre à réssuciter. Mais bon on ne peut pas utiliser d'array sinon on serait de mettre ça dans une boucle. Alors si vous avez une idée, ce ne serait pas de refus (en language simple svp) Merci. RE: Optimisation script (requête SQL) - Ter Rowan - 26-08-2008 à mon sens ça ne marchera pas, les $max venant de la requête il faut mettre dans le sql Code PHP :
mais je ne sais pas trop faire ces requêtes croisées, pas sûr que cela marche comme ça RE: Optimisation script (requête SQL) - Joojo - 27-08-2008 Scusez pour le retard, j'ai du partir peu après. Donc comme l'a dit Ter Rowan j'ai dut enlever les variables et j'ai enlevé "monstres.temps" de la selection de la requête secondaire. J'ai aussi dut remplacer NOW par time, sql ma dit qu'il ne connaissait pas. Tout celà pour arriver à: Operand should contain 1 column(s) UPDATE map_monstres SET vie_monstre = monstres.vie_max_monstre, exp_monstre = monstres.exp_max_monstre, timestamp = '. time() .' WHERE id_id_monstre IN (SELECT map_monstres.id_id_monstre, map_monstres.timestamp, monstres.vie_max_monstre, monstres.exp_max_monstre FROM monstres INNER JOIN map_membres INNER JOIN map_monstres ON map_monstres.id_case = map_membres.id_case AND map_membres.login_membre = "'. $_COOKIE['pseudo'] .'" AND map_monstres.vie_monstre = 0 AND monstres.id_monstre = map_monstres.id_monstre AND ('. time() .' - timestamp) >= temps) Mais il y a un truc qui m'embête là la requête va comparer id_id_monstre à id_id_monstre, timestamp, vie_max_monstre, exp_max_monstre? RE: Optimisation script (requête SQL) - Joojo - 27-08-2008 Le problème c'est que maintenant j'ai une autre erreur: You can't specify target table 'map_monstres' for update in FROM clause En recherchant je suis tombé la dessus: vous ne pouvez pas effectuer un UPDATE avec une sous-requête SELECT travaillant sur la même table, pour effectuer cette requête, vous devez créer une table temporaire qui fera la passerelle entre le SELECT et l'UPDATE. http://www.developpez.net/forums/d494961/bases-donnees/mysql/requetes/cant-specify-target-in-from-clause/ Bref cela m'a l'air plus casse bonbec qu'autre chose. edit: j'ai essayé ceci et ça a l'air de fonctionner: UPDATE map_monstres INNER JOIN map_membres INNER JOIN monstres SET vie_monstre = vie_max_monstre, exp_monstre = exp_max_monstre, timestamp = '. time() .' WHERE map_monstres.id_case = map_membres.id_case AND map_membres.login_membre = "'. $_COOKIE['pseudo'] .'" AND map_monstres.vie_monstre = 0 AND monstres.id_monstre = map_monstres.id_monstre AND ('. time() .' - timestamp) >= temps re-edit: après quelques tests rapides cette requête fonctionne bien, merci à tous les deux pour votre aide |