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

Langage PHP Discussion :

Parcours avec la fonction Foreach


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 56
    Points : 42
    Points
    42
    Par défaut Parcours avec la fonction Foreach
    Salut,
    J'ai du mal à comprendre le fonctionnement de foreach, j'au beau cherché et lu sur les forums, mais j'arrive pas à formuler mon problème avec cette fonction!
    J'ai un tableau qui contient tout les noms de cours de mon site.
    Je veux parcourir ce tableau et faire des tests pour chaque cours.
    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
    $traceEnOrdre  = array('la recursivite','les pointeurs','les listes','les piles et files','les arbres'); //tab noms des cours
            foreach ($traceEnOrdre as &$value)
            {
              $res111=mysql_query("SELECT DISTINCT lienvisite , nomcour, dureevisite FROM trace WHERE pseudo= '$pseudo' and nomcour= '$value'
                               and lienvisite = 'exemple' or 'resume' or 'exercice' ORDER BY heurvisite") or die(mysql_error());   
            /* ici je veoulais récupérer les liens dont le user a visité tant qu'il est connecté sur un cours
               Le problème est sur la ligne qui contient le where! précisément  avec (nomcour = $value), je crois ?
            */
             $j=0;
             $traceOrdre4 = array();
             $dureelecture = array();
             while($rep1=mysql_fetch_array($res1))
             {
             $traceOrdre4[$j]=$rep1['lienvisite'];
             $dureelecture[$j]=$rep1 ['dureevisite'];
             $j++;
             }
              $res1=mysql_query("SELECT test  FROM reponse WHERE pseudo= '$pseudo' ") or die(mysql_error());   
              $contenu=mysql_query($sql114) or die('Erreur SQL !'.$sql114.'<br />'.mysql_error());
              $dLecture = array_sum ($dureelecture);
             if (($traceOrdre4[0] == $traceOrdre3[0]) and
                 ($traceOrdre4[1] == $traceOrdre3[1]) and
                 ($traceOrdre4[2] == $traceOrdre3[2]) and
                 ($dLecture >= $Tps) and
                 ( empty($contenu))
                 )
                    {  
                     $styleApprentissage["rigueur"][2]=0.7; //pour paresseux
                     $styleApprentissage["rigueur"][1]=0.3; //pour sérieux
                    }  else {
                             $styleApprentissage["rigueur"][2]=0.3; //pour paresseux
                              $styleApprentissage["rigueur"][1]=0.7; //pour sérieux}
                            }
                }
    Je vous remercie d'avance pour vos remarques.

  2. #2
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    tu fais $res111=mysql_query("SELECT DISTINCT ...") et ensuite tu fais while($rep1=mysql_fetch_array($res1)), attention $res1 n'existe pas c'est $res111.

    Tu devrais activer l'affichage de toutes les erreurs quand tu codes avec au début du script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ini_set('display_errors', 1);
    ini_set('display_startup_errors', 1);
    error_reporting(-1);
    $pseudo vient d'où ?

  3. #3
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 56
    Points : 42
    Points
    42
    Par défaut
    j'ai corrigé la faute de $res1, mais c'est pas la cause du problème!
    $pseudo vient des pages précédentes.

  4. #4
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Corrige aussi ton SQL
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    and ((lienvisite = 'exemple') or (lienvisite = 'resume') or (lienvisite = 'exercice'))
    Après ton code n'est pas super clair.
    Le nommage des variables est assez obscur.

  5. #5
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    J'ai repris le début de ton 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
    $sql_data = array(
        'pseudo' => mysql_real_escape_string($pseudo)
    );
     
    $liste_cours = array('la recursivite', 'les pointeurs', 'les listes', 'les piles et files', 'les arbres'); //tab noms des cours
     
    foreach ($liste_cours as $cours)
    {
        $sql_data['cours'] = mysql_real_escape_string($cours);
     
        $sql = <<<SQL
    SELECT DISTINCT
        lienvisite,
        nomcour,
        dureevisite
    FROM
        trace
    WHERE
        pseudo = '{$sql_data['pseudo']}'
        AND nomcour = '{$sql_data['cours']}'
        AND ((lienvisite = 'exemple')
                OR (lienvisite = 'resume')
                OR (lienvisite = 'exercice'))
    ORDER BY
        heurvisite
    SQL;
     
            $res111 = mysql_query($sql);
    en y incluant l'échappement des données.

    Au fait les fonction mysql_* sont obsolètes, tu dois passer sur mysqli_* ou PDO

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    C'est plus lisible avec un IN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND lienvisite IN ('exemple', 'resume', 'exercice')

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

Discussions similaires

  1. Retourner une valeur avec une fonction
    Par stephtbest dans le forum ASP
    Réponses: 4
    Dernier message: 31/10/2003, 17h37
  2. [Postgresql]Problème avec les fonctions ...
    Par fet dans le forum Requêtes
    Réponses: 4
    Dernier message: 02/10/2003, 10h04
  3. Réponses: 13
    Dernier message: 20/03/2003, 09h11
  4. [VBA-E] avec une fonction value
    Par laas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 28/11/2002, 14h22

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