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 :

GROUP BY dans plusieurs champs


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Points : 46
    Points
    46
    Par défaut GROUP BY dans plusieurs champs
    Bonjour j'ai une table comportant des doublons ils sont des champs communs matricule et nom et de prenom différents. Je veux faire le groupement sur tous les champs mais je n'arrive pas à le faire.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT COUNT(matricule) AS NBR_DOUBLES, t1.matricule, t1.NOM
     
     
    FROM   tb1 t1 join tb2 t2 on t2.matric=t1.matricule
     and t1.prenom =t2.prenom
    group by t1.matricule,t1.nom ;
    si j'ajoute le prenom dans le group by ça ne marche pas?

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 801
    Points
    30 801
    Par défaut
    Citation Envoyé par LILIFA Voir le message
    sa ne marche pas?
    Ceci n'est pas la description d'une erreur... juste un constat.

    Qu'est-ce qui ne fonctionne pas ?
    Le résultat n'est pas bon ? Il faudrait montrer un exemple, avec quelques lignes en entrée, ce qui est retourné et ce qui était attendu.
    Le SGBD retourne un message d'erreur ? Quel est alors ce message... ?
    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.

  3. #3
    Membre du Club
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Points : 46
    Points
    46
    Par défaut
    La requête marche bien mais le résultat de la close count(*) n'est pas bon car j'ai deux personne de même matricule mais de prenom différent que le group by ne regroupe pas.
    voir l'exemple ci-jointe.
    Fichiers attachés Fichiers attachés

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 801
    Points
    30 801
    Par défaut
    A quoi sert la jointure avec tb2 sur le le prénom ?
    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.

  5. #5
    Membre du Club
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Points : 46
    Points
    46
    Par défaut
    tb2 c'est une autre table qui des informations que je voudrais afficher aussi. tb1 et tb2 ont un champs en commun qui est le matricule.
    Fichiers attachés Fichiers attachés

  6. #6
    Membre averti
    Avatar de diablo-dz
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2014
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2014
    Messages : 75
    Points : 327
    Points
    327
    Par défaut
    bonsoir
    tu dis que tb2 c'est une deuxième table , et moi je vois
    FROM tb1 t1 JOIN tb2 t2 ON t2.matric=t1.matricule
    AND t1.prenom =t2.prenom

    je crois que dans la tb2 ne contient pas le champ prénom
    plus d'informations pour bien concerner ton problème .
    A++
    Si une réponse vous a permis d'avancer , n'oublie pas de mettre
    Ne pas oublier

  7. #7
    Membre du Club
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Points : 46
    Points
    46
    Par défaut
    Oui diablo-dz tu sais je peu dire que l'une est la table tampon tb1 et tb2 est la table métier je compare les enregistrement toute les lignes qui sont dans tb1 sont dans tb2. je pense que vous mavez saisis maintenent?

  8. #8
    Membre averti
    Avatar de diablo-dz
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2014
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2014
    Messages : 75
    Points : 327
    Points
    327
    Par défaut
    Citation Envoyé par LILIFA Voir le message
    tb2 c'est une autre table qui des informations que je voudrais afficher aussi. tb1 et tb2 ont un champs en commun qui est le matricule.
    la première foi t’a pas dis ça
    al1_24

    A quoi sert la jointure avec tb2 sur le le prénom ?
    tu peux répondre a la question de al1_24
    Si une réponse vous a permis d'avancer , n'oublie pas de mettre
    Ne pas oublier

  9. #9
    Membre du Club
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Points : 46
    Points
    46
    Par défaut
    c' est pour afficher les enregistrements de même prénom dans les deux tables. Mais bon j'ai rétifié.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT COUNT(matricule) AS NBR_DOUBLES, t1.matricule, t1.NOM
    FROM   tb1 t1 JOIN tb2 t2 ON t2.matric=t1.matricule
    GROUP BY t1.matricule,t1.nom ;

  10. #10
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 278
    Points : 74
    Points
    74
    Par défaut
    Afin de simplifier la gestion des erreurs, il faut mettre or die et ton message. De la sorte si ta requête SQL n'est pas bonne, il t'affichera le message. Le plus simple est d'afficher ta requête SQL en cas d'erreur, tu trouveras facilement où elle plante. Si tu ne mets pas le or die, prends en compte du message d'erreur affiché.

Discussions similaires

  1. [SQL] count group dans plusieurs champs
    Par rduvrac dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 07/04/2008, 10h18
  2. Réponses: 1
    Dernier message: 13/03/2007, 09h52
  3. Réponses: 3
    Dernier message: 21/01/2007, 10h40
  4. Réponses: 7
    Dernier message: 26/10/2006, 15h13
  5. [SQL Server] rechercher dans plusieurs champs d'une table
    Par houla! dans le forum Langage SQL
    Réponses: 3
    Dernier message: 23/08/2006, 09h37

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