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 :

Bug à retardement


Sujet :

PHP & Base de données

  1. #1
    Membre éclairé
    Homme Profil pro
    Educateur spécialisé
    Inscrit en
    Janvier 2012
    Messages
    238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Educateur spécialisé
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2012
    Messages : 238
    Par défaut Bug à retardement
    Bonjour à tous et à toutes.
    J'ai fait un petit script pour afficher des marques qui sont dans une bdd par ordre alphabétique et de haut en bas.
    Le script à fonctionné quelque jours puis maintenant plus rien.
    Voici le script :
    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
     
    <?php
    echo'<p><img class="fl" src="'.ROOTPATH.'/images/img/zcode/zcode_attention.png" alt="Attention : " />
    			<span class="fond_Violet Gris_Clair">Les marques de nos cartouches d\'encre par ordre alphabétique de haut en bas.</span></p><br/>';
    				echo'<p class="centre"><font face="segoe print">Veuillez choisir la marque.</font></p>';
    		$nbrcol = 3;
    		$requete = mysql_query("SELECT $debut_requette FROM $table $millieu_requette $fin_requette")or die(mysql_error());
    		$nbreponse = mysql_num_rows($requete);
    		$tier = ceil($nbreponse/$nbrcol);
     
    		while ($result = mysql_fetch_array($requete))
    			{
    				$marque[] = $result["marque"];
    				$TYPE[] = $result["TYPE"];
    				$gamme[] = $result["gamme"];
    				$POUR_IMPRIMANTE[] = $result["POUR_IMPRIMANTE"];
     
    			}
    		echo '<table><tr><td>';
     
    		for ($i=0; $i<$nbreponse; $i++)
    			{
    				if($i == $tier)
    					{
    						echo "</td><td>";
    						$tier=$tier*2;
    					}
    				echo '<img src="../images/go.png"/>
    				<a href="'.ROOTPATH.'/index.php?page=cartouche&amp;choix='.urlencode($choix).'&amp;marque='.urlencode($marque[$i]).'&amp;type='.urlencode($TYPE[$i]).'&amp;gamme='.urlencode($gamme[$i]).'&amp;imprimante='.urlencode($POUR_IMPRIMANTE[$i]).'">';
    				echo ''.$marque[$i].'</a><br>';
    			}
    		echo "</td></tr></table>";
    ?>
    Merci d'avance pour votre aide car je ne vois pas ou ça coince.

  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
    Quel résultat obtiens-tu ? une page blanche ? une erreur ? un affichage non conforme ? des resultats erronés ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éclairé
    Homme Profil pro
    Educateur spécialisé
    Inscrit en
    Janvier 2012
    Messages
    238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Educateur spécialisé
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2012
    Messages : 238
    Par défaut
    Bonjour sabotage et merci de ton aide.
    Je pense avoir trouvé, en tout cas pour le moment ça fonctionne.
    J'avais oublié de déclarer mes array
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $marque = array();
    $TYPE = array();
    $gamme = array();
    $POUR_IMPRIMANTE = array();
    Encore merci

  4. #4
    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
    A tout hasard, tu peux initialiser les tableaux avant la boucle while :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $marque = array();
    $TYPE = array();
    $gamme = array();
    $POUR_IMPRIMANTE = array();
    while ($result = mysql_fetch_array($requete))
    {
    	$marque[] = $result["marque"];
    	$TYPE[] = $result["TYPE"];
    	$gamme[] = $result["gamme"];
    	$POUR_IMPRIMANTE[] = $result["POUR_IMPRIMANTE"]; 
    }
    Autre alternative : construire l'affichage directement dans la boucle while :
    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
    echo '<table><tr><td>';
    $i=0;
    while ($result = mysql_fetch_array($requete))
    {
    	if($i == $tier)
    	{
    		echo "</td><td>";
    		$tier=$tier*2;
    	}
    	echo '<img src="../images/go.png"/>
    	<a href="'.ROOTPATH.'/index.php?page=cartouche&amp;choix='.urlencode($choix).'&amp;marque='.urlencode($result["marque"]).'&amp;type='.urlencode($result["TYPE"]).'&amp;gamme='.urlencode($result["gamme"]).'&amp;imprimante='.urlencode($result["POUR_IMPRIMANTE"]).'">';
    	echo ''.$result["marque"].'</a><br>';
    	$i++;
    }
    echo "</td></tr></table>";
    Pour information, l'API mysql (autrement dit les fonctions mysql_xxx) est obsolète en PHP5.5+ et sera supprimée en PHP7. Il va falloir envisager de passer à PDO (ou mysqli)
    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]

  5. #5
    Membre éclairé
    Homme Profil pro
    Educateur spécialisé
    Inscrit en
    Janvier 2012
    Messages
    238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Educateur spécialisé
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2012
    Messages : 238
    Par défaut
    Merci Celira.
    J'était justement en train d'éditer mon poste car j'avais trouvé.
    C'était bien l'oublie de déclaration de mes array qui faisait planter.

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

Discussions similaires

  1. Le lancement de Windows 7 retardé par un bug ? Apparemment pas
    Par Gordon Fowler dans le forum Windows
    Réponses: 28
    Dernier message: 10/08/2009, 09h15
  2. Le lancement de Windows 7 retardé par un bug ? Apparemment pas
    Par Gordon Fowler dans le forum Actualités
    Réponses: 28
    Dernier message: 10/08/2009, 09h15

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