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 SQL Discussion :

Union sur les dates?


Sujet :

Langage SQL

  1. #1
    Membre confirmé
    Inscrit en
    Mai 2004
    Messages
    91
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 91
    Par défaut Union sur les dates?
    Bonjour,

    J'ai une requete qui me ramène des données sur un intervalle de temps.
    ex: select count(), année, mois
    -> 2, 2007, 03
    3, 2007, 05

    Le probleme est que lorsque qu'il n'y a pas de données pour un mois, par exemple, aucune ligne n'est ramenée (logique)

    J'aimerais que mon count donne 0 lorsqu'il n'y a rien sur un mois!.
    -> 2, 2007, 03
    0, 2007, 04
    3, 2007, 05

    Comment faire?

    Merci.

  2. #2
    Membre chevronné Avatar de chrifo
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    444
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 444
    Par défaut
    Bonjour,
    On pourra vous proposer des solutions plus ou moins pratiques seon votre sgbd, quel est-il ?

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 500
    Par défaut
    Une requête ne peux pas te ramener des lignes qui ne sont pas dans la table !

    Dans ce cas, la solution est d'avoir une table de référence sur le couple (année, mois), et de mettre la table de données en jointure externe avec la table de référence, sélectionner année, mois dans la table de référence, et faire le count() dans la table de données.

  4. #4
    Membre éprouvé Avatar de reno_tidus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    132
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 132
    Par défaut
    Ceci devrait faire l'affaire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select nvl(count(),0), année, mois...

  5. #5
    Membre confirmé
    Inscrit en
    Mai 2004
    Messages
    91
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 91
    Par défaut
    si j'ai bien compris, je crée une table année, mois, semaines et je fais une jointure?

    j'essaie.. eu... y aurait il une personne qui sait comment créer cet table des mois semaines années?

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Je vous invite à prendre connaissance des règles à lire avant de poster sur ce forum
    En précisant le SGBD que vous utilisez et sa version, les réponses proposées seront adaptées aux spécificités et limitations de celui-ci.

    Vous trouverez de nombreuses informations sur la gestion du temps dans le document Calendrier, timing et horaires en SQL...
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  7. #7
    Membre confirmé
    Inscrit en
    Mai 2004
    Messages
    91
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 91
    Par défaut
    oracle 10g, jdbc

  8. #8
    Membre éprouvé Avatar de reno_tidus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    132
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 132
    Par défaut
    Dans ce cas, la fonction nvl que je t'ai donné plus tôt fonctionnne très bien ...

  9. #9
    Membre chevronné Avatar de chrifo
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    444
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 444
    Par défaut
    Citation Envoyé par reno_tidus
    Dans ce cas, la fonction nvl que je t'ai donné plus tôt fonctionnne très bien ...
    Comment utilisez-vous nvl dans ce cas là ?


    Citation Envoyé par doudine Voir le message
    oracle 10g, jdbc
    Vous pouvez donc utiliser "level" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT COUNT(ma_table.mois), mon_perimetre.annee, mon_perimetre.mois 
      FROM 
    	   (SELECT DISTINCT TO_CHAR(ADD_MONTHS(ADD_MONTHS(SYSDATE,-36),LEVEL),'yyyy') annee, TO_CHAR(ADD_MONTHS(ADD_MONTHS(SYSDATE,-36),LEVEL),'mm') mois 
    	      FROM dual 
    		  CONNECT BY LEVEL<=72) mon_perimetre 
    	left outer join ma_table ON mon_perimetre.annee=ma_table.annee AND mon_perimetre.mois=ma_table.mois
      GROUP BY mon_perimetre.annee, mon_perimetre.mois

Discussions similaires

  1. Equivalent à TRUNC ou ROUND d'Oracle sur les Dates ?
    Par swirtel dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/05/2005, 09h45
  2. operation sur les dates
    Par elendil dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 13/04/2005, 12h14
  3. [C#] Calcul sur les dates avec des DateTimePicker
    Par alizee971 dans le forum Windows Forms
    Réponses: 10
    Dernier message: 02/04/2005, 17h14
  4. MS Access et TQuery (probleme sur les dates)
    Par Djob dans le forum C++Builder
    Réponses: 4
    Dernier message: 15/06/2004, 14h57
  5. opérations sur les dates
    Par coucoucmoi dans le forum Débuter
    Réponses: 2
    Dernier message: 12/08/2003, 11h45

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