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 :

Gestion du cas IS NULL [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    389
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 389
    Par défaut Gestion du cas IS NULL

    Dans ma base de données, il y a deux champs donnant des infos sur le nombre de sites et l'effectif d'une entreprise A la saisie, si on ne connait pas cette information, on laisse le champ vide. Le champ contient alors NULL comme valeur.

    Pour afficher seulement les entreprises dont le champ n'est pas renseigné, je fais :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if ($_SESSION['nbSitesNR'] != '') {//Si la valeur NR est renseignée
    	$requete .= " AND NbSites IS NULL";
    }
    sinon, je fais :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if ($_SESSION['nbSitesNR'] == '' && $_SESSION['nbSitesMax'] != '') {//Si la valeur MAX est renseignée (au moins un client dans la base)
    	$requete .= "AND NbSites BETWEEN ".$_SESSION['nbSitesMin']." AND ".$_SESSION['nbSitesMax']." ";
    }

    Comment faire pour regrouper les deux (afficher à la fois les entreprises dont le nombre de site est compris entre 10 et 20 par exemple, et aussi celles dont le nombre de sites n'est pas renseigné) ?

    Je ferai pareil pour l'effectif ensuite.


  2. #2
    Membre expérimenté
    Profil pro
    Développeur Web
    Inscrit en
    Mai 2008
    Messages
    185
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2008
    Messages : 185
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    	$requete .= " AND ( ( NbSites BETWEEN ".$_SESSION['nbSitesMin']." AND ".$_SESSION['nbSitesMax'] . " ) OR ( NbSites IS NULL ) ) " ;
    Comme ça, par exemple !

    Bonne journée !

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    389
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 389
    Par défaut
    Merci, ça fonctionne très bien!
    Topic

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

Discussions similaires

  1. [AC-2010] Gestion de dates is null
    Par HABILER dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 13/09/2014, 07h56
  2. Angle orienté deux vecteurs: gestion des cas particuliers
    Par darkman19320 dans le forum Mathématiques
    Réponses: 5
    Dernier message: 17/12/2013, 19h26
  3. [VBA-E]Cbx - gestion de la valeur null
    Par Tartenpion dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 19/02/2006, 10h44
  4. pb de jointure : cas ou une clé étrangère est à NULL
    Par tiboleo dans le forum Langage SQL
    Réponses: 4
    Dernier message: 19/11/2004, 11h31
  5. Gestion des null
    Par Bruno75 dans le forum Décisions SGBD
    Réponses: 19
    Dernier message: 20/09/2004, 13h34

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