IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Optimisation d'une boucle [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut Optimisation d'une boucle
    Bonjour,

    Je fait une page où j'affiche les données de la base de données.
    J'aimerais ajouter une ligne à chaque entrée dans la base de données, c'est pour cela que j'ai fait une boucle et pas faire un tableau en entier à chaque entrée.

    Voici la requête SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query_selection_devoirs_eleves = mysql_query("SELECT matiere_cours_devoirs_eventuels,classe_cours_devoirs_eventuels,date_depot_cours_devoirs_eventuels,date_devoirs_eventuels,resume_cours_devoirs_eventuels,nom_auteur_devoirs_eventuels FROM test_site_questions,test_site_utilisateur WHERE pseudo_utilisateur='$pseudo_utilisateur' AND type_devoir='3'")or die ('Erreur lors de la requête SQL'.mysql_error());

    Voici le code (boucle) que j'ai fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    echo '<table width="100%" border="1">';
    echo '<tr><td colspan="2">Cahier de texte de la Classe :'.$donnees_devoirs_eleves['classe_cours_devoirs_eventuels'].'</td></tr>';
    while ($donnees_devoirs_eleves = mysql_fetch_array($query_selection_devoirs_eleves)) {
    $nombre_de_devoirs = mysql_num_rows($query_selection_devoirs_eleves);
     
    for ($i = 1; $i < $nombre_de_devoirs; $i++) {
     
       echo '<tr><td width="60">Date de dépot'.$donnees_devoirs_eleves['date_depot_cours_devoirs_eventuels'].'<br />Date (pour quand)'.$donnees_devoirs_eleves['date_devoirs_eventuels'].'</td><td>Matière : '.$donnees_devoirs_eleves['matiere_cours_devoirs_eventuels'].html_entity_decode($donnees_devoirs_eleves['resume_cours_devoirs_eventuels']).$donnees_devoirs_eleves['nom_auteur_devoirs_eventuels'].'&nbsp;</td></tr>
    ';
    }
    }
    echo '</table>';
    Ce code à l'air de fonctionner mais j'ai mis d'entrée dans la boucle .

    Qu'est-ce que vous en pensez ?

    A mon avis, il y a (peut-être) des améliorations à faire...

    Cordialement

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Je ne vois pas à quoi sert ta boucle for.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut
    Je t'explique ce que je voudrais faire avec ce code :

    Je voudrais faire un code qui permettrait de rajouter les données issues de la base de données dans ce cahier de texte pour éviter de faire un tableau dès qu'il y a un nouveau enregistrement.

    Je précise que ce code à l'air de marcher mais ce qui m'étonne, c'est que si je mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for ($i = 1; $i < $nombre_de_devoirs; $i++)
    , ça à l'air de fonctionner alors que si je mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for ($i = 0; $i < $nombre_de_devoirs; $i++)
    , ça m'affiche les données en double.

    Pourquoi ?

    Voilà, je me pose cette question !!!

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Je ne vois toujours la logique de ce que tu fais.

    mysql_fetch_array renvoit 1 ligne de résultat.

    ta boucle for à l'intérieur du while conduit forcemment à la répétition de cette ligne plusieurs fois.

    je suppose que $nombre_de_devoirs = 1 donc quand $i = 1, ta boucle for ne fait rien
    et quand $i = 0 ta boucle for tourne deux fois.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut
    En fait, c'est un cahier de texte pour les élèves : quand un professeur met un devoir pour telle date, ça l'affiche sur cette page.
    A chaque enregistrement d'un devoir, je n'insère pas un tableau mais j'ajoute des lignes pour une question de présentation.

    Voilà.

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Donc c'est bien ce que je dis : ta boucle for ne sert à rien.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut
    Qu'est-ce que tu proposes ?

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    de la retirer
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut
    Peux-tu me donner ta version comme exemple STP ?

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    La même chose sans le for :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    while ($row = mysql_fetch_array($query_selection_devoirs_eleves)) {
    	echo '<tr>
    			<td width="60">Date de dépot'.$row['date_depot_cours_devoirs_eventuels'].'<br />Date (pour quand)'.$row['date_devoirs_eventuels'].'</td>
    			<td>Matière : '.$row['matiere_cours_devoirs_eventuels'].$row['resume_cours_devoirs_eventuels'].$row['nom_auteur_devoirs_eventuels'].'&nbsp;</td>
    		</tr>';
    };
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Par défaut
    Bonjour,

    Merci de ta réponse.

    Par contre, j'ai une autre question : s'il y a aucun enregistrement (au début), comment afficher un message (par exemple : Aucune donnée trouvée.) sachant que pour éviter que ça le fasse plusieurs fois, j'ai mis
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    echo '<table width="100%" border="1">';
    echo '<tr><td colspan="2" class="titre">Cahier de texte de la Classe : ';
    while ($donnee_selection_classe_eleve = mysql_fetch_array($query_selection_classe_eleves)) {
       echo "<div class='classe'>".$donnee_selection_classe_eleve['classe_cours_devoirs_eventuels']."</div>";
    }
    '</td></tr>';
    avant mes deux boucles.

    Actuellement même s'il y a aucune donnée trouvée, le début du tableau s'affiche sans le nom de la classe ce qui est logique.

    En une question : comment ne pas afficher le début du tableau quand il y a aucun enregistrement trouvé et afficher un message du type Aucune donnée trouvée. ?

    Cordialement

  12. #12
    Membre émérite Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    601
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 601
    Par défaut
    Bonjour.
    Il me semble que tu n'as qu'a coder ce que tu écris !
    Un if sur la valeur du nombre d'enregistrement. Si c'est zéro, tu affiches ton message, sinon tu rentres dans le while
    Tu as déjà presque tout codé :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $nombre_de_devoirs = mysql_num_rows($query_selection_devoirs_eleves);

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. erreur pendant l'optimisation d'une boucle for
    Par bakaratoun dans le forum MATLAB
    Réponses: 2
    Dernier message: 29/01/2010, 14h44
  2. Optimisation d'une boucle
    Par habasque dans le forum R
    Réponses: 2
    Dernier message: 12/11/2009, 19h55
  3. Optimisation d'une boucle for
    Par Vorlane dans le forum MATLAB
    Réponses: 0
    Dernier message: 07/07/2009, 11h36
  4. Optimisation d'une boucle
    Par ccobaye dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 28/08/2008, 08h28
  5. [Debutant] Optimisation d'une boucle
    Par Javatator dans le forum Langage
    Réponses: 3
    Dernier message: 25/10/2004, 18h50

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo