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 :

Code pas totalement fonctionnel [SQL-Server]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 7
    Points : 8
    Points
    8
    Par défaut Code pas totalement fonctionnel
    Bonjour,

    Je tente de faire apparaitre les plantes mellifères, fruits et légumes des mois en cours, mais j'ai un petit souci au niveau des plantes mellifères, autant les 2 premiers mois tout s'affiche nickel, autant par la suite ils se répètent une puis à plusieurs reprises, pour mieux visualiser le problème, voici la page en question : http://co-nexion.com/page/allsaisons

    Le code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    <?php
        $db = Zend_Registry::get('database');
        echo "<center><h1>Plantes méllifères, aromates, fruits, légumes, salades et champignons de saison</h1></center><br /><br />";
        $mois = array("", "Janvier", "Février", "Mars", "Avril", "Mai", "Juin", "Juillet", "Août", "Septembre", "Octobre", "Novembre", "Décembre" );
        for ($i = 1; $i <= 12; $i++)
        {
            $select1 = "SELECT * FROM saisonapicole WHERE Mois='$mois[$i]'";
            $toElect1 = $db->fetchAll($select1, array(), Zend_Db::FETCH_ASSOC);
            echo '<center><h3>' . $mois[$i] . '</h3></center>';
            $OldCat1 = '';
            foreach ($toElect1 as $elect1)
            {
         $Fleurs=$elect1['Fleurs'];
         $Cat1 = $elect1['Categorie'];
                if (($OldCat1 == '') || ($Cat1 != $OldCat1))
                {
                    // si on est en début d'itération (OldCat vide)
                    // OU qu'on a changé de catégorie (OldCat et Cat différents)
                    // afficher le nom de catégorie ET l'aliment
                    echo '<br /><strong>Plantes méllifères</strong> : ' . $Fleurs;
                } else
                {
                    // sinon afficher juste l'aliment précédé d'une virgule
                    echo ', ' . $Fleurs;
                }
                $OldCat1 = $Cat1; // mettre a jour l'ancienne catégorie avec la courante pour le test a la prochaine itération
            }
        echo "<br />";
        $select = "SELECT * FROM saison WHERE Mois='$mois[$i]' ORDER BY Categorie";
            $toElect = $db->fetchAll($select, array(), Zend_Db::FETCH_ASSOC);
        $OldCat = '';
        foreach ($toElect as $elect)
            {
                $Cat = $elect['Categorie'];
                $Aliment = $elect['Nom'];
                if (($OldCat == '') || ($Cat != $OldCat))
                {
                    // si on est en début d'itération (OldCat vide)
                    // OU qu'on a changé de catégorie (OldCat et Cat différents)
                    // afficher le nom de catégorie ET l'aliment
                    echo '<br /><strong>' . $Cat . 's</strong> : ' . $Aliment;
                } else
                {
                    // sinon afficher juste l'aliment précédé d'une virgule
                    echo ', ' . $Aliment;
                }
                $OldCat = $Cat; // mettre a jour l'ancienne catégorie avec la courante pour le test a la prochaine itération
            }
            echo "<br /><br />";
        }
        ?>
    Les tables :
    saison : Id, Nom, Categorie, Mois
    saisonapicole : Id, Fleurs, Mois, Special, Categorie


    Pourriez vous m'aider à résoudre ce problème ? Je sais que les tables ne sont pas optimales mais je ne suis pas doué en jointures... D'avance merci.

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Je ne vois pas bien ton problème de repetition sur la page.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 7
    Points : 8
    Points
    8
    Par défaut
    En effet au début de page il n y a pas de problème mais dès le mois de mars les données se répètent. Je n'avais pas ce problème avant le rajout du code avec la table saisonapicole.

  4. #4
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 235
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 235
    Points : 15 532
    Points
    15 532
    Par défaut
    montre nous la structure de tes tables

  5. #5
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    @ Sabotage
    Plantes méllifères : Saule marsault, Saule marsault, Anémone sylvie, Anémone sylvie, Epine noire, Epine noire, Prunus (merisier, mirabellier, pêcher…), Prunus (merisier, mirabellier, pêcher…), Pissenlit, Pissenlit, Colza, Colza, Miellées industrielles, Miellées industrielles, Pommiers, Pommiers

    En avril, tout est en double par exemple

    @Shaka

    Ton PHP est nickel.
    Ce doit être ton SQL.
    Teste ces requêtes dans ton interface graphique de db

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT distinct Fleurs,Categorie 
    FROM saisonapicole 
    WHERE Mois="Avril"
    /*Si j'ai bien compris tu n'utilises que ces 2 champs et le rendu est différent de */
     
    SELECT * 
    FROM saisonapicole 
    WHERE Mois="Avril"
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 7
    Points : 8
    Points
    8
    Par défaut
    Eh bien parfait, c'était bien SELECT DISTINCT, tout simplement ! Merci beaucoup !

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

Discussions similaires

  1. [RegEx] code pas trop fonctionnel
    Par kaking dans le forum Langage
    Réponses: 6
    Dernier message: 09/11/2010, 12h18
  2. Return, mais pas totalement
    Par maxdef dans le forum MATLAB
    Réponses: 3
    Dernier message: 29/06/2007, 12h29
  3. Libérer une form, pb memoire pas totalement rendu.
    Par flash dans le forum Composants VCL
    Réponses: 4
    Dernier message: 07/10/2004, 14h43

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