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 :

Utilisation de DISTINCT


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 14
    Points : 8
    Points
    8
    Par défaut Utilisation de DISTINCT
    salut tous le monde
    j'ai une table qui contient des noms prénom avec biensur des id qui sont des auto incrémant
    je veux afficher les noms avc suppression de doublons c a d DISTINCT mais chaque non avec son id
    j'utilise
    SELECT DISTINCT non, id from membres
    mais ca me sort tous les noms sans suppression des doublons
    ca prend pas compte de mon distinct !!!

  2. #2
    Membre habitué Avatar de Cobaye
    Profil pro
    Développeur Web
    Inscrit en
    Décembre 2002
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2002
    Messages : 120
    Points : 154
    Points
    154
    Par défaut
    si ton id est unique c'est normal, le distinct se fait sur tous les champs !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DISTINCT nom FROM membres
    et la tu n'aura pas de doublons
    Pro : http://www.ohweb.fr -> Spécialiste en développement de site e-commerce, Expert Prestashop
    perso : http://www.olecorre.com -> un dico de termes informatiques


    J'ai toujours rêvé d'un ordinateur qui soit aussi facile à utiliser qu'un téléphone. Mon rêve s'est réalisé : je ne sais plus comment utiliser mon téléphone. [Bjarne Stroustrup]

  3. #3
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Points : 1 775
    Points
    1 775
    Par défaut
    Pour avoir l'id associé à chaque nom unique dans ta table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT ID, NOM
    FROM MEMBRES M1
    WHERE EXISTS (
        SELECT M2.NOM
        FROM MEMBRES M2
        WHERE M1.NOM = M2.NOM
        GROUP BY M2.NOM
        HAVING COUNT(M2.NOM) = 1 );
    Modérateur des forums Oracle et Langage SQL
    Forum SQL : je n'interviens PAS plus de 4 fois dans une discussion car si c'est nécessaire cela prouve généralement que vous n'avez pas respecté : les règles du forum

  4. #4
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 14
    Points : 8
    Points
    8
    Par défaut merci
    Citation Envoyé par Magnus
    Pour avoir l'id associé à chaque nom unique dans ta table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT ID, NOM
    FROM MEMBRES M1
    WHERE EXISTS (
        SELECT M2.NOM
        FROM MEMBRES M2
        WHERE M1.NOM = M2.NOM
        GROUP BY M2.NOM
        HAVING COUNT(M2.NOM) = 1 );
    merci ami; mais c quoi M1, M2 ??

  5. #5
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 14
    Points : 8
    Points
    8
    Par défaut non
    Citation Envoyé par Cobaye
    si ton id est unique c'est normal, le distinct se fait sur tous les champs !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DISTINCT nom FROM membres
    et la tu n'aura pas de doublons
    non t'a pas compris il me faut les id de chaque champs noms selectionné

  6. #6
    BiM
    BiM est déconnecté
    Expert éminent sénior
    Avatar de BiM
    Femme Profil pro
    Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT
    Inscrit en
    Janvier 2005
    Messages
    7 796
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT

    Informations forums :
    Inscription : Janvier 2005
    Messages : 7 796
    Points : 10 765
    Points
    10 765
    Par défaut
    Donne un exemple d'affichage que tu veux faire...

    1.
    DUPONT
    123
    456
    253
    DURAND
    324
    305
    321
    354
    ...

    2.
    DUPONT 123, 456, 253
    DURAND 324, 305, 321, 354
    ...

    3.
    DUPONT 123
    DUPONT 456
    DUPONT 253
    DURAND 324
    DURAND 305
    DURAND 321
    DURAND 354
    ...

    4.
    DUPONT | DURAND
    123 | 324
    456 | 305
    253 | 321
    | 354


    5. Autre, donc quoi ?

  7. #7
    BiM
    BiM est déconnecté
    Expert éminent sénior
    Avatar de BiM
    Femme Profil pro
    Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT
    Inscrit en
    Janvier 2005
    Messages
    7 796
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT

    Informations forums :
    Inscription : Janvier 2005
    Messages : 7 796
    Points : 10 765
    Points
    10 765
    Par défaut Re: merci
    Citation Envoyé par vanmouniren
    Citation Envoyé par Magnus
    Pour avoir l'id associé à chaque nom unique dans ta table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT ID, NOM
    FROM MEMBRES M1
    WHERE EXISTS (
        SELECT M2.NOM
        FROM MEMBRES M2
        WHERE M1.NOM = M2.NOM
        GROUP BY M2.NOM
        HAVING COUNT(M2.NOM) = 1 );
    merci ami; mais c quoi M1, M2 ??
    M1 C'est la premiere table MEMBRES
    M2 C'est la table MEMBRES de la requête imbriquée

Discussions similaires

  1. linq to xml utilisation de distinct
    Par morel0077 dans le forum Linq
    Réponses: 2
    Dernier message: 27/05/2011, 12h23
  2. Utilisation de DISTINCT ou pas ?
    Par passpartout007 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 16/12/2010, 01h19
  3. Utilisation de Distinct sur un seul champ!
    Par Bils dans le forum Langage SQL
    Réponses: 10
    Dernier message: 21/11/2007, 09h31
  4. [SQL] Utilisation de distinct
    Par toddy_101 dans le forum PHP & Base de données
    Réponses: 29
    Dernier message: 03/01/2007, 16h52
  5. Utilisation de Distinct
    Par qwert33 dans le forum Langage SQL
    Réponses: 11
    Dernier message: 23/06/2006, 09h54

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