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 :

requete + include [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 88
    Par défaut requete + include
    Bonsoir,

    je vous présente mon tit problème, un fichier qui include un autre rien de spécial sauf que la requête est faite dans l'un et utilisé dans l'autre et que ça bug ^^

    je vous entend déjà crier "le code, le code" alors le voici:
    fichier appelant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    $result = mysql_query($query);
    	if (!$result) {
    	   die('Impossible d\'exécuter la requête :' . mysql_error());
    	}
    	if (mysql_num_rows($result)){
    		include("produit.php");
    	}else{?>
    	<div class="error">Aucun produit ne correspond à cette référence</div>
    	<?php
    	}
    fichier appelé:
    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
    	<?php
    	while ($row = mysql_fetch_array($result)) {?>
    		<tr>
    			<td>
    				<img src="<?php echo $row["image"]; ?>" width="300" height="210" />			</td>
    			<td class="texte_ligne">
    				<?php echo $row["ref_novo"]; ?>
    			</td>
    			<td class="texte_ligne">
    				<?php echo $row["ref_construct"]; ?>
    			</td>
    			<td class="texte_ligne">
    				<?php echo $row["description"]; ?>
    			</td>
    		</tr>
    <?php
    	}
    ?>
    et enfin la petite erreur:

    Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in D:\Logiciels\wamp\wamp\www\novo2\produit.php on line 25
    la ligne 25 c'est: while ($row = mysql_fetch_array($result)) {?>

    Je croyais que les variables pouvaient être utilisé dans les fichiers includes... voila j'espère que quelqu'un pourras m'éclairer

  2. #2
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    L'erreur est très certainement dans le $query...

    Il ne faut jamais mettre un code sans montrer la requête, car PHP te retournera une erreur à la ligne du mysql_fetch_....() si tu ne met pas de mysql_error() alors que l'erreur est TOUJOURS dans la requête !

    corrige ceci :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $result = mysql_query($query);

    en mettant :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $result = mysql_query($query) or die($query."<br />".mysql_error());

    Ensuite, dis-nous quel est le message retourné et donne-nous ta requête ($query = ...)

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 88
    Par défaut
    Et bien en faite comme le prouve ce code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if (!$result) {
    	   die('Impossible d\'exécuter la requête :' . mysql_error());
    	}
    placé après l'exécution de la requête, cette dernière ne crée pas d'erreur mais j'essaierais quand j'aurais mon PC de dev sous la main

    pour info la requête est toute bête et fonctionne parfaitement bien puisqu'avant de faire mon include j'affichais le résultat.
    La requête a cette forme (dans les grandes lignes) avec le numéro récupéré entre les deux lignes.
    Le numéro existe j'ai effectué les "tests basiques" (affichage de chaque variable, vérification du fonctionnement de la requête) seul l'include parait poser un problème

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $query= "select * from table1 where numero=";
    $query .= "'".$numero."'";
    Merci de ton aide je te fournirais ce soir des informations plus complète quand j'aurais mon code sous les yeux ^^

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 88
    Par défaut
    voila le code exacte j'ai essayer de rajouter le test derrière la requête ça ne change rien la requête ne provoque pas d'erreur je ne comprend pas

    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
    	$query= "SELECT id_produit, ref_novo, ref_construct, image, description FROM produits WHERE ref_novo=";
    	$reference= preg_replace("#[.\\/_-]+#", "",$_POST["novotec"]);
    	if (strlen($reference)!=7){
    		$pblong = 1;
    	}
    	$ref = preg_replace('#([0-9]{2})([0-9]{2})([0-9]{3})#',"$1.$2.$3",$reference);
    	$query .= "'".$ref."'";
    }elseif($_POST["constructeur"]){
    	$query= "SELECT id_produit, ref_novo, ref_construct, image, description FROM produits WHERE ref_construct=";
    	$reference= preg_replace('#[.\\/_-]+#', "",$_POST["constructeur"]);
    	if (strlen($reference)!=6){
    		$pblong = 1;
    	}
    	$ref = preg_replace('#([0-9]{3})([0-9]{3})#',"$1.$2",$reference);
    	$query .= "'".$ref."'";
    }
    if ($pblong==1){
    ?>
    <div class="error">Cette référence est invalide</div>
    <?php
    }else{
    	$result = mysql_query($query) or die($query."<br />".mysql_error());
    	echo $query;
    	if (!$result) {
    	   die('Impossible d\'exécuter la requête :' . mysql_error());
    	}
    	if (mysql_num_rows($result)){
    		include("produit.php");
    	}else{?>

  5. #5
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    erf oui désolé, j'avais mal regardé et j'avais pas vu que tu avais mis le mysql_error()...


    Si tu fais un echo de $query, qu'est-ce que ça affiche ?

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 88
    Par défaut
    oulala j'ai trouver mon erreur mais elle étais tellement énorme que je l'avais pas vu
    dans mon fichier appelé j'ai un bo switch case au dessus dont la valeur par default fais une autre requête avec $result

    donc c'est normal qu'il n'y ai rien en plus celle la était pas protégé par un or die


    bouhouhou honte sur moi et merci à toi

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

Discussions similaires

  1. [MySQL] page include contenant une requete -> Erreur
    Par sp2308 dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 09/09/2014, 12h59
  2. [MySQL] requete SQL et include PHP
    Par camyo dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 18/04/2010, 11h55
  3. requete SQL et include PHP
    Par camyo dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 15/04/2010, 16h35
  4. requete avec OBCD et visual c++
    Par Anonymous dans le forum MFC
    Réponses: 12
    Dernier message: 18/11/2004, 16h15
  5. [Kylix] Requetes Kylix pour postgres
    Par Miltown dans le forum EDI
    Réponses: 1
    Dernier message: 29/05/2002, 20h22

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