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 :

Migration PHP4 vers 5.3


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 196
    Par défaut Migration PHP4 vers 5.3
    Bonjour,

    Je migre une appli vers PHP5.3.
    J'ai des problèmes de variables, les principaux je sais les résoudre, ils sont liés à POST et GET, mais j'en ai quelques uns qui me donnent du fil à retordre car l'appli a été développée par qqn d'autre...

    Donc j'ai ce genre d'erreurs :
    Notice: Undefined variable: listeStages in F:\Intranet\SerfaEval\CalculStats.php on line 44
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    		$req = "SELECT id_stage FROM stages WHERE resp_stage = '$cdm' AND id_stage LIKE '$numero'";
    		$res = mysql_query($req, $connexion);
    		while ($stages = mysql_fetch_object($res))
    			$listeStages[] = $stages->id_stage;
     
    /*l.44*/		$clause = Clause($listeStages);
    Notice: Undefined variable: listeStages in F:\Intranet\SerfaEval\CalculStats.php on line 55

    Notice: Undefined variable: stages in F:\Intranet\SerfaEval\CalculStats.php on line 281

    Notice: Undefined variable: stages in F:\Intranet\SerfaEval\CalculStats.php on line 282

    Notice: Undefined variable: stages in F:\Intranet\SerfaEval\CalculStats.php on line 283

    Notice: Undefined variable: stages in F:\Intranet\SerfaEval\CalculStats.php on line 290
    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
    		$req = "SELECT participation, contenu, pedagogie, deroulement, total FROM modules WHERE id_module = '1' AND $clause";
    		$res = mysql_query($req, $connexion);
    		while ($stage = mysql_fetch_array($res))
    			$stages[] = $stage;
     
    		$moyenne[0] = $nb; //nb total de formations
    		if ($nb ==0)
    		$moyenne[1]=0;
    		else
    		$moyenne[1] = EvalSignificatives($stages, $participation); //nb d'évaluations significatives
    		if ($moyenne[0] > 0) 
    			$tauxSign = $moyenne[1] / $moyenne[0] * 100;
    		else $tauxSign = 0;
    		$moyenne[2] = number_format($tauxSign, 0, ',', ' '); //% d'évaluations significatives
    		$moyenne[3] = number_format($retour, 0, ',', ' '); //taux retour questionnaires
    /*l.281*/		$moyenne[4] = CalculeMoyenne($stages, 1, $participation); //contenu
    /*l.282*/		$moyenne[5] = CalculeMoyenne($stages, 2, $participation); //pédagogie
    /*l.283*/		$moyenne[6] = CalculeMoyenne($stages, 3, $participation); //déroulement
    Notice: Undefined variable: liste in F:\Intranet\SerfaEval\CalculStats.php on line 207
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    		$req = "SELECT id_stage FROM modules WHERE id_module = '1' AND $clause AND participation >= '$participation'";
    		$res = mysql_query($req, $connexion);
    		while ($stage = mysql_fetch_object($res))
    			$liste[] = $stage->id_stage;
     
    /*l.207*/		$clause2 = Clause($liste);
    Notice: Undefined variable: liste2 in F:\Intranet\SerfaEval\CalculStats.php on line 227

    Notice: Undefined variable: result in F:\Intranet\SerfaEval\CalculStats.php on line 243
    Bref c'est chaque fois des erreurs du même type lorsque le résultat de la requête est affectée à un tableau apparemment...
    Je ne fonctionne pas comme ça, moi j'ai appris :
    while ($stage = mysql_fetch_assoc($res))
    $liste = $res["id_stage"];

    et du coup le $liste[] = $stage->id_stage; me déroute un peu !

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Attention, sans accolades une expression conditionnelle ne s'applique qu'à l'expression directement après.
    Et si tu veux remplir un tableau, il vaut mieux l'avoir déclaré vide avant. (comme ça, si jamais il n'y a rien à mettre dedans, tu auras quand même un tableau vide dans ta variable...)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $listeStages = array();
    while ($stages = mysql_fetch_object($res))
    {
    	$listeStages[] = $stages->id_stage;
    }
     
    $clause = Clause($listeStages);
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 196
    Par défaut
    Citation Envoyé par Celira Voir le message
    Attention, sans accolades une expression conditionnelle ne s'applique qu'à l'expression directement après.
    Oui ça je sais, c'est justement le cas ici...

    Par contre bien vu le coup du tableau vide, j'avais pas pensé à ça !
    Merci !

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

Discussions similaires

  1. [MySQL] Migration PHP4 vers PHP5
    Par Gamil dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 19/03/2009, 14h52
  2. Migration PHP4 vers PHP5 sur sarge puis etch
    Par elspliffo dans le forum Debian
    Réponses: 2
    Dernier message: 28/06/2008, 00h23
  3. [Oracle] Migration PHP4+oracle 8i vers PHP5+oracle 9i
    Par erox44 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 14/03/2008, 14h05
  4. [Migration]java vers C
    Par chelguera dans le forum Général Java
    Réponses: 1
    Dernier message: 14/01/2005, 19h09
  5. Migration HyperFile vers SQL SERVER
    Par mathll65 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 23/03/2004, 09h57

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