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 :

Problème de doublons dans une requète complexe


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 36

    Informations forums :
    Inscription : Mars 2008
    Messages : 154
    Points : 66
    Points
    66
    Par défaut Problème de doublons dans une requète complexe
    Bonjour,
    J'ai un souci avec une requète, voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT DISTINCTROW CSP.CSP ,Count(*) AS [Compte De FORMATION] 
    FROM (CSP INNER JOIN EMPLOYE ON CSP.CSP = EMPLOYE.CSP) INNER JOIN FORMATION ON EMPLOYE.Matricule = FORMATION.Matricule
    WHERE (((FORMATION.DateDebut)<="31/12/" & (Year(Now())-1) And (FORMATION.DateDebut)>="01/01/" & (Year(Now())-1)) AND ((EMPLOYE.Sexe)="M") AND ((FORMATION.Statut)="Définitive")) AND ((FORMATION.Imputation)="Oui")
    GROUP BY CSP.CSP;
    Cette requète m'indique le nombre de formation où un employé MASCULIN à participé, et ce classé par catégorie socio professionel(CSP).
    Seulement je voudrais compter une seul fois un employé qui a fait plusieurs formations, mais je n'arrive pas a rédiger ma requete.
    J'ai essayé avec un distinct FORMATION.Matricule dans le count(*) qui permet d'identifier un employé mais ca ne marche pas.
    Si quelqu'un à la solution...
    Merci d'avance

  2. #2
    say
    say est déconnecté
    Membre expérimenté
    Avatar de say
    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 176
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 176
    Points : 1 300
    Points
    1 300
    Par défaut
    merci de préciser le SGBD. (access?)

    la syntaxe peut varier.

    c'est ça que tu as essayé? :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT 
    CSP.CSP ,Count(DISTINCT EMPLOYE.Matricule ) AS [Compte De FORMATION] 
    FROM (CSP INNER JOIN EMPLOYE ON CSP.CSP = EMPLOYE.CSP) INNER JOIN FORMATION ON EMPLOYE.Matricule = FORMATION.Matricule
    WHERE (((FORMATION.DateDebut)<="31/12/" & (Year(Now())-1) 
    AND (FORMATION.DateDebut)>="01/01/" & (Year(Now())-1)) AND ((EMPLOYE.Sexe)="M") AND ((FORMATION.Statut)="Définitive")) 
    AND ((FORMATION.Imputation)="Oui")
    GROUP BY CSP.CSP;
    Ils ne savaient pas que c'était impossible alors ils l'ont fait (Mark Twain)
    _ _ _ _ _ _ _ _ _

    La planète ne nous appartient pas, elle nous a été prêtée par nos enfants
    _ _ _ _ _ _ _ _ _

    Technos : Access, C++ Builder, SQL, PostgreSQL, Crystal Reports, XML entre autres

  3. #3
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 36

    Informations forums :
    Inscription : Mars 2008
    Messages : 154
    Points : 66
    Points
    66
    Par défaut
    Non, en fait j'ai essayé COUNT(*) et COUNT(DISTINCT(FORMATION.Matricule)), *)

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 774
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 774
    Points : 52 743
    Points
    52 743
    Billets dans le blog
    5
    Par défaut
    DISTINCTROW n'existe pas en SQL c'est une merdouille d'Access qui provoque plus de dégâts qu'autre chose. Pour solutionner votre requête vous pouvez utiliser un COUNT(DISTINCT employe) sur la bonne table.

    Si vous voulez de l'aide, donnez le DDL de vos tables. En cela vous respecterez la charte de postage de ce forum : http://www.developpez.net/forums/ann....php?f=37&a=69

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 281
    Points : 11 737
    Points
    11 737
    Par défaut
    Pour info, le COUNT(DISTINCT) n'existe pas en Access. Il faut faire une première requête en SELECT DISTINCT, puis une seconde qui compte les lignes ramenées par la première.

    Quant au DISTINCTROW, SQLpro en a parfaitement résumé l'intérêt .
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  6. #6
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 36

    Informations forums :
    Inscription : Mars 2008
    Messages : 154
    Points : 66
    Points
    66
    Par défaut
    Ah je ne savais pas pour le DISTINCTROW. Mais justement, c'est une requete que je fais sous access 2003... En fait le but de cette requète est de remplir un avis fiscal, ça rempli donc un champs de l'avis (Grâce à un formulaire) (Je ne sais pas si vous pourrai me répondre vu que c'est le forum SQL)
    Pour la table CSP: Catégorie socio professionel:
    Il y a juste un champ texte CSP ex : Cadre , ouvrier...
    Pour la table FORMATION ce qui importe ici sont les champs
    dateDebut ex : 01/01/2007
    dateFin ex :05/12/2007
    Matricule ex : 6011235
    Imputation ex : Oui
    Statut ex : Définitive
    Pour la table employé :
    Matricule ex : 6011235.
    Sexe ex : M
    CSP ex : Ouvrier
    J'éspère que ceci vous aidera à comprendre ce que j'ai besoin.
    Merci

  7. #7
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 281
    Points : 11 737
    Points
    11 737
    Par défaut
    Citation Envoyé par Antoun Voir le message
    Pour info, le COUNT(DISTINCT) n'existe pas en Access. Il faut faire une première requête en SELECT DISTINCT, puis une seconde qui compte les lignes ramenées par la première.
    Bon, j'explicite :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT CSP, Count(EMPLOYE.Matricule ) AS [Compte De FORMATION] 
    FROM (
      SELECT DISTINCT CSP.CSP, EMPLOYE.Matricule
      FROM (CSP INNER JOIN EMPLOYE ON CSP.CSP = EMPLOYE.CSP) 
         INNER JOIN FORMATION ON EMPLOYE.Matricule = FORMATION.Matricule
      WHERE (((FORMATION.DateDebut)<="31/12/" & (Year(Now())-1) 
        AND (FORMATION.DateDebut)>="01/01/" & (Year(Now())-1)) 
        AND   ((EMPLOYE.Sexe)="M") AND ((FORMATION.Statut)="Définitive")) 
        AND ((FORMATION.Imputation)="Oui")
    ) AS Tempo
    GROUP BY CSP.CSP;
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  8. #8
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 36

    Informations forums :
    Inscription : Mars 2008
    Messages : 154
    Points : 66
    Points
    66
    Par défaut
    Ah super le résultat à l'air cohérent, je pense que ça marche, c'est super MERCI!!
    Vous êtes les meilleurs!!!!!

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

Discussions similaires

  1. Doublons dans une requète complexe
    Par noakiss dans le forum VBA Access
    Réponses: 0
    Dernier message: 19/03/2008, 15h30
  2. Problème de décimales dans une requête
    Par pellec dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 21/07/2006, 08h15
  3. [10g] Problème de privilège dans une requête
    Par hotkebab99 dans le forum Oracle
    Réponses: 6
    Dernier message: 01/03/2006, 12h00
  4. Problème de perfomances dans une requête
    Par claralavraie dans le forum Langage SQL
    Réponses: 1
    Dernier message: 05/01/2006, 14h25
  5. Problème de débutant dans une requête
    Par decour dans le forum Access
    Réponses: 7
    Dernier message: 14/10/2005, 14h17

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