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 :

Compter le nombre de doublons


Sujet :

Langage SQL

  1. #1
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Points : 188
    Points
    188
    Par défaut Compter le nombre de doublons
    Bonjour,

    j'essaie dans une table de compter le nombre de doublons.

    Pour cela, j'utilise cette requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT reftache_err.nomreftache
    FROM reftache_err
    GROUP BY reftache_err.nomreftache
    HAVING Count(reftache_err.nomreftache)>1);
    Elle fonctionne bien, mais ne me donne pas le résultat que je voudrais:
    par exemple:
    nomreftache1
    nomreftache2

    En fait, elle me donne le nom de chaque élément qui contient un doublon.
    Or, je voudrais qu'elle me compte le nombre total, càd qu'elle me compte le nombre d'enregistrements qui ont des doublons.

    Donc j'ai fait cette requête:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT COUNT(nomreftache)
    FROM reftache_err
    WHERE nomreftache IN (
    SELECT reftache_err.nomreftache
    FROM reftache_err
    GROUP BY reftache_err.nomreftache
    HAVING Count(reftache_err.nomreftache)>1);
    Celle-ci me donne le résultat que je cherchais.

    ...sauf que là, le temps de chargement est énorme !

    Environ 30 secondes pour une table de 2500 enregistrements.

    Et tout ça, juste pour compter le résultat d'une requête !

    Quelqu'un a une solution à ce problème ?
    (\ _ /)
    (='.'=) Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant.

  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 803
    Points
    30 803
    Par défaut
    Et pour quoi pas tout simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT  COUNT(*)
    FROM    
        (   SELECT  nomreftache
            FROM    reftache_err    
            GROUP BY nomreftache
            HAVING  COUNT(*) > 1
        )   AS dbl
    ;
    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 habitué
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Points : 188
    Points
    188
    Par défaut
    Effectivement...

    ça fonctionne très bien, et très rapidement.

    Le résultat de la requête est correct, sauf que j'ai ce message en même temps :

    Showing rows 0 - 0 (1 total, Query took 0.0125 sec)
    Notice: Undefined offset: 0 in C:\Program Files\EasyPHP 2.0b1\phpmyadmin\libraries\sqlparser.lib.php on line 1193

    Notice: Undefined offset: 0 in C:\Program Files\EasyPHP 2.0b1\phpmyadmin\libraries\sqlparser.lib.php on line 1194

    ça ne doit pas être grand chose....

    mais c'est quoi exactement ?
    (\ _ /)
    (='.'=) Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant.

  4. #4
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Points : 188
    Points
    188
    Par défaut
    Un autre problème aussi:

    Je voudrais stocker le résultat de la requête dans une variable, donc j'ai mis ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT  COUNT(*) INTO @NombreDoublons
    FROM    
        (   SELECT  nomreftache
            FROM    reftache_err    
            GROUP BY nomreftache
            HAVING  COUNT(*) > 1
        )   AS dbl
    ;
    Mais quand je fais un select sur ma variable, elle retourne Null.

    Pourquoi ?
    (\ _ /)
    (='.'=) Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant.

  5. #5
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Points : 188
    Points
    188
    Par défaut
    Petite modification :
    cela ne fonctionne pas dans l'interface PhpMyAdmin, mais ça tourne en console MySql, donc ça me va.
    Pour le message d'erreur dont je parle dans mon post précédent, il n'apparaît plus.

    Donc tout est OK pour moi !

    Merci pour le coup de main !

    (\ _ /)
    (='.'=) Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant.

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

Discussions similaires

  1. [Toutes versions] Compter le nombre de cellules sans doublons avec une condition
    Par Mimita64 dans le forum Excel
    Réponses: 2
    Dernier message: 02/12/2012, 20h39
  2. Réponses: 3
    Dernier message: 27/07/2012, 11h25
  3. Compter le nombre de doublons d'un tableau
    Par benji1000 dans le forum Langage
    Réponses: 4
    Dernier message: 03/11/2011, 11h14
  4. compter le nombre d'apparitions d'un doublon
    Par Mapokko dans le forum Excel
    Réponses: 3
    Dernier message: 23/12/2008, 14h23
  5. Compter le nombre de lignes sans les doublons
    Par byrdo dans le forum Excel
    Réponses: 15
    Dernier message: 15/06/2007, 14h30

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