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

MS SQL Server Discussion :

Jointure outer join ne match pas les colonnes [2005]


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut Jointure outer join ne match pas les colonnes
    Bonjour,

    Je suis en train de réaliser une requête SQL avec une double jointure externe.

    Voici ma première vue de date :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Create View ViewAnneeMoisDemande as (
    select distinct Year(d.dateCreationD) 'annee', Month(d.dateCreationD) 'mois'
    from demande d right outer join (select distinct YEAR(dateCreationD) 'A', MONTH(dateCreationD) 'M' FROM demande) as m 
    on Year(d.dateCreationD)= m.A AND Month(d.dateCreationD)= m.M)
    Elle me renvoi une liste de dates tel que : 2014 01, 2014 02, 2014 03 -> ce sont toutes celles utilisées dans la table Demande.

    Ma deuxième table est celle des Demandes qui comporte une numéro de demande, la date, et un numéro de statut.
    Je veux regrouper par année et par mois (de la vue viewAnneeMoisDemande), le nombre de demande par statut.
    Voici ce que j'ai écrit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select count(Numéro), d.Année, d.Mois
    from Demande d left outer join ViewAnneMoisDemande v on d.Année= v.annee AND  d.Mois = v.mois
    where d.Statut = 2
    group by d.Année, d.Mois
    La requête me retourne le cumul des demandes pour le statut 2 par année et par mois, mais uniquement lorsque qu'il y a eut des demandes. Donc il ne m'affiche pas 0 lorsqu'il n'y a pas de demande. Alors qu'avec un outer join, si je ne me trompe pas, elle devrait me renvoyer 0 ou null pour toute les autres dates de la vue ViewAnneeMoisDemande.
    Merci à ceux qui pourront m'aider

    Dorian
    Dernière modification par Chtulus ; 10/06/2014 à 20h27. Motif: Utiliser la liste déroulante devant le titre afin d'indiquer votre version

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Par défaut
    Si c'est la vue qui définit les lignes,

    essayez

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT count(Numéro), v.Année, v.Mois
    FROM ViewAnneMoisDemande v LEFT OUTER JOIN Demande d ON d.Année= v.annee AND  d.Mois = v.mois
    WHERE isnull(d.Statut,2) = 2
    GROUP BY d.Année, d.Mois
    ou quelque chose qui ressemble

    A+

  3. #3
    Invité
    Invité(e)
    Par défaut
    Merci de ta réponse Donpi, mais j'ai exactement le même résultat,.
    Seulement 3 lignes à la place d'une quinzaine..

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour

    Sans entrer dans le détail, il me semble que vous avez inversé la jointure externe. essayez avec un RIGHT OUTER JOIN

  5. #5
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    heu...

    En entrant un peu plus dans le détail :

    1/ je ne comprends pas l’espèce d'auto-jointure sur la table demande dans votre vue. Quel en est l’intérêt ?

    2/ Si vous voulez être certain d'avoir toutes les dates, il faudrait vous appuyer sur une table calendrier.

    3/ sinon, vous pouvez faire comme ceci :

    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
     
    SELECT 
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,dateCreationD
    		)
    		,0
    	) AS Mois
    	,COUNT(*) AS NbDemandes
    FROM Demande
    WHERE Statut = 2
    GROUP BY 
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,dateCreationD
    		)
    		,0
    	)
    Si vous voulez compter les demandes ayant le statut 2, mais obtenir dans le résultat les mois pour lesquels il n'y a pas eu de demande avec le statut 2, mais des demandes avec d'autres statut, vous pouvez faire comme ceci (même si là déjà, la table calendrier serait préférable)
    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
     
    SELECT 
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,dateCreationD
    		)
    		,0
    	) AS Mois
    	,SUM(CASE WHEN Statut = 2 THEN 1 ELSE 0 END) AS NbDemandes
    FROM Demande
    GROUP BY 
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,dateCreationD
    		)
    		,0

  6. #6
    Invité
    Invité(e)
    Par défaut
    J'avais essayé right et left.
    Ta dernière requête répond parfaitement à ma question !
    Jamais je n'aurai pensé à faire ce que tu as fais. Merci beaucoup.
    Après, je voulais regrouper par statut et faire en sorte, comme dans ce que tu as fais, que pour les statuts ou il n'y a pas de résultat, il s'affiche zéro.
    Par exemple si j'ai 3 mois de dates et qu'il y a 8 statuts, je devrai avoir 8*3 lignes = 24.
    Si tu repasses par là, merci à toi sinon je le ferai dans mon code coté serveur en parcourant les statuts.

    Dorian

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

Discussions similaires

  1. [SQL-Server] Echo ne montre pas les colonnes :(
    Par Dev_Ucf dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 27/04/2014, 22h31
  2. [XL-2010] Somme qui ne prend pas les colonnes masqués
    Par RodKAZ dans le forum Excel
    Réponses: 1
    Dernier message: 05/03/2013, 15h27
  3. OUTER JOIN: première valeur pas prise
    Par Nibor dans le forum Requêtes
    Réponses: 5
    Dernier message: 11/09/2008, 13h11
  4. Left outer join, ne marche pas
    Par lido dans le forum Forms
    Réponses: 5
    Dernier message: 04/06/2008, 12h05
  5. Jointure "outer join"
    Par so007 dans le forum Hibernate
    Réponses: 5
    Dernier message: 22/08/2006, 10h30

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