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

Requêtes MySQL Discussion :

HAVING et NULL


Sujet :

Requêtes MySQL

Vue hybride

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

    Informations forums :
    Inscription : Septembre 2002
    Messages : 144
    Par défaut HAVING et NULL
    Bonjour,

    Quand on teste une valeur NULL dans une clause HAVING on obtient une erreur du type
    Unknown column ma_colonne in 'having clause'
    La doc mysql est claire (elle éclaire aussi) :
    Par exemple, vous ne pourrez pas ajouter HAVING product IS NULL pour éliminer certains résumés qui ne vous intéressent pas.
    Pour ma part, je souhaite conserver des résultats qui correspondent à un maximum (donc pas possible de le placer dans un WHERE), ainsi que les résultats NULL. Un mix avec des fonctions IFNULL ne marche pas non plus.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    GROUP BY t1.`cle_fact` , t1.`date_fact`
    HAVING t1.`date_fact` = MAX( IFNULL( t2.`date_fact` , t1.`date_fact` ) )
    Alors quid ? Merci à vous

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Par défaut
    salut,

    tu peux donner un petit exemple ?

    Merci

    Michel

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 144
    Par défaut
    Bonjour,

    J'ai simplifié le code. Il s'agit de lister les numéros d'abonnement avec la date de la dernière facture (parfois il n'y en a pas, mais il faut lister quand même), en parallèle de la facture en cours qui elle n'a pas été envoyée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT t1.cle_fact, t1.abonnement, t1.date_fact, t2.date_fact AS dern_fact_envoyee
    FROM ma_base AS t1
    INNER JOIN ma_base AS t2 ON t1.`abonnement` = t2.abonnement AND t2.`date_fact` < t1.`date_fact` AND t2.`fact_envoyee` = 'O'
    GROUP BY t1.cle_fact, t2.date_fact
    Merci à vous

  4. #4
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Par défaut
    avec une jointure externe peut etre?

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 144
    Par défaut
    Merci cybher,

    en fait, dans le dernier code que j'ai mis, il n'y a plus le having, et ça semble marcher (pour combien de temps... ?)

    Ce message peut faire suite à un autre post : http://www.developpez.net/forums/sho...d.php?t=548053

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

Discussions similaires

  1. Réponses: 20
    Dernier message: 24/06/2011, 23h22
  2. Réponses: 1
    Dernier message: 04/04/2011, 23h16
  3. Problème avec NULL dans HAVING
    Par Jean-Marc68 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 06/11/2007, 14h01
  4. [VB6] [BDD] Recordset et champ égal à Null
    Par Gr|ppen dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 07/03/2003, 10h00
  5. "ALTERER" une col. NULL en NOT NULL - Int
    Par Gandalf24 dans le forum SQL
    Réponses: 2
    Dernier message: 28/12/2002, 00h07

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