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 :

condition if avant une requête sql


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    63
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 63
    Points : 58
    Points
    58
    Par défaut condition if avant une requête sql
    Bonjour,

    j’exécute le code suivant dans ma page php, quant la condition dans if() est vrais, la requête sql passe bien, mais quand la condition est fausse alors là la requête ne s'exécute pas. or, ce n'est pas le but du code. pourquoi?

    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
     
    $where=" `DateDepot` BETWEEN ".$date_debut." AND ".$date_fin;
    if($status != 'tout')
    	{$where .= " AND `statu`= ".$status." ";}
     
    	//********** requete de selestion des données **********
    $sql_indice_par_secteur = <<<EOF
    SELECT  
    	`SectrurPrincipal` AS SECTEUR_PRINCIPAL, 
    	COUNT( `idProjet` ) AS NOMBRE_PROJETS, 
    	SUM( `NombreEmplois` ) AS NOMBRE_EMPLOIS,
    	SUM( `MI` ) AS COUT_INVEST
    	FROM projet
    	WHERE $where
    	GROUP BY SECTEUR_PRINCIPAL
    EOF;

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Salut,

    `statu`
    tu es sûr que le nom de la colonne est comme ça?
    Et ce champ est de quel type? parce que tu ne l'as pas mis dans de quote dans la requête.

    EDIT, tu dois mettre la valeur de statu dans de quote
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {$where .= " AND `statu`= '".$status."' ";}
    A+.

  3. #3
    Membre du Club
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    63
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 63
    Points : 58
    Points
    58
    Par défaut
    je récupère les variable $status depuis le formulaire d'une autre page ainsi:

    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
     
    $date_debut="'".$_SESSION['dateD']."'";
    $date_fin="'".$_SESSION['dateF']."'";
    $status="'".$_SESSION['status']."'";
     
     
    //------------ Les pays investisseurs --------------------
    $where=" `DateDepot` BETWEEN ".$date_debut." AND ".$date_fin;
    if($status !='tout')
    	{
    		$where .= " AND `statu`= ".$status;
    	}
     
     
    $sql_pays = <<<EOF
    SELECT `PaysOrigine` AS PAYS
    FROM projet
    WHERE $where
    GROUP BY PAYS
    EOF;
    `statu` est de type "varchar(45)" dans ma base donnée MYSQL.

    j'ai fait un : echo "where=".$where; pour tester la valeur de cette variable, et j'ai remarqué que même dans le cas où $statu=tout, la condition if s'exécute:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if($status !='tout')
    	{
    		$where .= " AND `statu`= ".$status;
    	}
    donc , je dirai que c'est un problème de comparaison de chaîne.

    des idées?

    merci

  4. #4
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $status=$_SESSION['status'];
     
     
    //------------ Les pays investisseurs --------------------
    $where=" `DateDepot` BETWEEN ".$date_debut." AND ".$date_fin;
    if($status !='tout')
    	{
    		$where .= " AND `statu`= '".$status."' ";
    	}

  5. #5
    Membre du Club
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    63
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 63
    Points : 58
    Points
    58
    Par défaut
    oups, je l'ai oublié celle-ci

    Bien vu, merci beaucoup

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 30/03/2012, 13h56
  2. Erreur incompréhensible avec une condition if et une requête SQL
    Par Francky44003 dans le forum Bases de données
    Réponses: 6
    Dernier message: 16/04/2011, 18h09
  3. [SQL] Conditions dans une requête SQL
    Par NeO666Linux dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 02/07/2007, 23h35
  4. [MySQL] Condition suite à une requête SQL
    Par arnaudperfect dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 26/01/2007, 15h25
  5. [MySQL] concaténer une requête sql avec condition
    Par maliak dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 10/02/2006, 13h01

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