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 :

Requête COUNT ASSOCIATION


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut Requête COUNT ASSOCIATION
    Bonjour,
    Pour faire simple j'ai deux entrée (Ex: 1er colonne = Nom, 2eme colonne = Prénom) et j'aimerai compter le Nombre de Dupond qui s'appelle julien ou autre.
    En vrai dans ma base ce sont des chiffres mais j'aimerai compter et voir toutes les combinaisons qui existent et les compter.
    Tous les prénoms qui existe avec Dupond et compter ces combinaison et cela pour les différentes entrées de ma première colonne.

    Prénom Nom
    1 6
    3 7
    1 7
    2 9
    1 6
    2 6
    2 6
    3 7
    1 5
    2 8
    1 6
    3 7
    3 8
    2 9
    1 7

    Et j'aimerais un résultat de type :

    Prénom Nom Count
    1 5 1
    1 6 3
    1 7 2
    2 6 2
    2 8 1
    2 9 2
    3 7 3
    3 8 1


    Merci par avance <3

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 109
    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 109
    Points : 28 439
    Points
    28 439
    Par défaut
    Bonjour,

    Qu'as-tu déjà testé comme requêtes ?
    Où rencontres-tu un problème ?

  3. #3
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut
    Bonjour,
    J'avais essayé il y a quelques mois, ma difficulté était de souvenirs de faire le distinct sur le groupe sans faire de where pour chaque dans une boucle PHP qui de plus ferais un nombre de requêtes énorme.

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 344
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 344
    Points : 39 745
    Points
    39 745
    Billets dans le blog
    9
    Par défaut
    Pour calculer des agrégats, il faut utiliser GROUP BY

  5. #5
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut
    Oui et c'est là ou je bug....

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT COUNT(DISTINCT Nom, Prenom) FROM `ma_table`
    Je vais essayer d'y rajouter group by .... je ne sais trop où..

    J'ai trouvé ça sur internet....
    http://www.pgphil.ovh/forum/viewtopic.php?t=93

    Je viens d'essayer ça mais c'et pareil les résultats sont merdiques.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT Nom, Prenom, COUNT(DISTINCT Nom, Prenom) FROM `ma_table` GROUP by Nom
     
    SELECT Nom, Prenom, COUNT(DISTINCT Nom || '<->' || Prenom) FROM `ma_table` GROUP by Nom
     
    SELECT Nom, Prenom, COUNT(DISTINCT Nom || '<->' || Prenom) AS A FROM `ma_table` GROUP by A ....
    erreur syntaxe ça y est ça me saoule déjà le sql....

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 344
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 344
    Points : 39 745
    Points
    39 745
    Billets dans le blog
    9
    Par défaut
    vous n'avez pas besoin du DISTINCT, seulement du GROUP BY...

    pour chaque paire {nom, prenom} (critère de regroupement) vous comptez (count) le nombre d'occurrences :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select nom
         , prenom
         , count(*)
    from ma_table
    group by nom
           , prenom

  7. #7
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut
    Merci je ne voyais pas ça si simple mais comment je peux faire pour que le groupe marche dans les deux sens ?
    1,2 soit compté aussi avec 2,1 ?

    Je vais essayer ça !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select nom
         , prenom
         , count(distinct nom || '<->' || prenom)
    from ma_table
    group by nom
           , prenom
    ===> marche pas ...

  8. #8
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 344
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 344
    Points : 39 745
    Points
    39 745
    Billets dans le blog
    9
    Par défaut
    Dans les deux sens ? Il n'y a pas de sens puisque chaque combinaison des colonnes du groupe fera l'objet d'un comptage, on se ficher de l'ordre de définition des colonnes dans le groupe, le résultat sera identique.

  9. #9
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut
    J'aimerais que le couple 1,3 compte avec le couple 3,1.

  10. #10
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Ce n'est plus la meme demande...

    Si vous n'avez que deux colonnes, vous pouvez faire ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT 
        CASE WHEN Nom>Prenom THEN Nom ELSE Prenom END AS C1
        ,CASE WHEN Nom>Prenom THEN Prenom ELSE Nom END AS C2
        ,COUNT(*)
    FROM LaTable
    GROUP BY 
        CASE WHEN Nom>Prenom THEN Nom ELSE Prenom END 
        ,CASE WHEN Nom>Prenom THEN Prenom ELSE Nom END

  11. #11
    Membre à l'essai
    Homme Profil pro
    Manipulateur en electro-radiologie medicale
    Inscrit en
    Août 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Manipulateur en electro-radiologie medicale
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 21
    Points : 16
    Points
    16
    Par défaut
    Re bonjour merci tout d'abord pour votre aide.

    J'ai trouvé un truc du style sur internet mais j'avoue que je ne sais pas si le resultat est bon ! (Le résultat est bon !)
    Je vais essayer votre requête aussi voir si cela donne les mêmes chiffres ! (J'avoue je ne l'ai pas fait )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT nom, prenom, count(*) FROM ma_table group by LEAST(nom, prenom),GREATEST(nom, prenom)
    Merci, je n'ai pas essayé la formule proposé par "aieeeuuuuu", mais celle-ci au dessus fonctionne très bien !
    Merci à tous ceux qui m'ont aidé !

    +1 developpez.net <3

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

Discussions similaires

  1. Récuperer dans un formulaire le résultat d'une requête count
    Par jean-paul lepetit dans le forum IHM
    Réponses: 6
    Dernier message: 29/01/2007, 10h10
  2. Problème de requête count(*) avec DB2
    Par elsodiop dans le forum DB2
    Réponses: 3
    Dernier message: 30/11/2006, 16h11
  3. Requête count un peu chaud
    Par louroulou dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 23/06/2006, 14h43
  4. Requête Count(*)
    Par shr3dpit dans le forum Langage SQL
    Réponses: 10
    Dernier message: 04/05/2006, 15h21
  5. PB avec une requête Count
    Par Marion dans le forum ASP
    Réponses: 7
    Dernier message: 05/07/2004, 12h56

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