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 :

Suppression de doublons


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 20
    Par défaut Suppression de doublons
    Re-bonjour à tous,

    Bon voilà, dans un précédent topic, j'ai réussi à mettre une table à jour avec un autre table dans une autre bdd (sous access, avec 3 belles requêtes).

    Maintenant, je remarque que ce que j'obtiens est remplit de doublons (merci bien à la table source dont je ne suis pas l'auteur).

    Ma question est la suivante : Est-il possible avec une ou plusieurs requêtes sql d'obtenir un résultat sans doublons comme expliqué ici plus bas ?

    Table source :
    --------------
    Code_Prod - Lib_Prod - Prix_Prod

    A01 : bol : 5
    A01 : bol : 6
    A01 : bol : 3
    C125 : couvercle : 1.27
    C125 : couvercle : 1.27
    C125 : couvercle : 2.54
    D05 : couteau : 3
    D06 : fourchette : 3.5
    D06 : fourchette : 4.5


    Résultat souhaité :
    ------------------
    Code_Prod - Lib_Prod - Prix_Prod

    A01 : bol : 6
    C125 : couvercle : 2.54
    D05 : couteau : 3
    D06 : fourchette : 4.5


    En français : Pour un seul code_prod, ne garder que la ligne du prix le plus haut, même si certaine ligne ne comporte qu'un seul prix.

    A votre avis ?


    Marcant,
    Qui désespère d'avoir un jour une table vraiment propre...

  2. #2
    Xo
    Xo est déconnecté
    Membre Expert
    Avatar de Xo
    Inscrit en
    Janvier 2005
    Messages
    2 701
    Détails du profil
    Informations personnelles :
    Âge : 52

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 701
    Par défaut
    Salut,

    As-tu vu tous les tutos disponibles sur la page http://sql.developpez.com/

    Il y a en particulier celui-ci : Les doublons

    Peut-être peut-il t'aider à solutionner ton problème ?
    "Ce que l'on conçoit bien s'énonce clairement,
    Et les mots pour le dire arrivent aisément." Nicolas Boileau

    "Expliquer empêche de comprendre si cela dispense de chercher"

    Quiz Oracle : venez tester vos connaissances !

    La FAQ Oracle : 138 réponses à vos questions
    Aidez-nous à la compléter

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 20
    Par défaut
    Re,

    Ben j'avais déjà été voir cette solution, mais je sais pas vraiment si dans mon cas ca va être interressant, car là, il traite des doublons quasi parfait (problème de case, de numéro ID, ...) Moi, c'est juste des prix qui diffèrent pour un même identifiant.

    Je vais essayer de faire un tri en ne reprennant que les ligne ou le prix est le plus haut pour le même identifiant, mais je ne sais pas si ca va marcher.

    J'essaye et je vous tiens au courant...


    Marcant.

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    140
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 140
    Par défaut
    Bonjour,

    Ton problème n'est pas un problème de doublon, tu veux juste faire une agrégation.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    select Code_Prod, Lib_Prod, max( Prix_Prod)
    from MaTable
    group by Code_Prod, Lib_Prod

  5. #5
    Membre confirmé
    Inscrit en
    Décembre 2004
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 150
    Par défaut
    Est-ce que tu essaies de supprimer les doublons?

    Sinon que veux-tu faire de tes doublons?

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 20
    Par défaut
    Alors là ... ... ... Bravo lol !!!

    C'était simple mais fallait y penser ;-)

    Avec un copain, on était arrivé à creer une belle requete qui nous donnait quasi la même chose, mais en nettement plus hard. Mais c'était buggé, car on avait des doublons en cas de prix à 0.

    La requete :

    SELECT DISTINCT (SELECT Prod1.articlereference, Prod1.ArticleLibelleFR, Prod1.ArtPrixBrut
    FROM Prod AS Prod1
    WHERE 0>=(SELECT count(Prod2.Articlereference) FROM Prod as Prod2 WHERE Prod1.articlereference=Prod2.articlereference AND Prod1.artPrixBrut<Prod2.ArtPrixBrut));

    Alors qu'avec ta solution, c'est simple et surtout très éfficace !!! J'en reste un peu abbassourdi !

    Ben un tout grand merci à toi !


    Marcant,
    Vraiment content ;-)

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 20
    Par défaut
    Salut Nadine,

    Désolé mais la solution donnée avant toi par mdevlieg sans apaprement marcher sans la moindre faille.

    J'obtiens maintenant une table avec une seule référence par produit et avec le prix le plus élévé... ce qu'il me fallait quoi.

    Donc, voilà, je vais passer le topic en résolu !


    Un tout grand merci à tous ceux qui se sont interressés à mon problème !


    Marcant.

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

Discussions similaires

  1. Suppression de doublons et insertion
    Par Samish dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/08/2005, 21h57
  2. Réponses: 17
    Dernier message: 03/12/2004, 11h17
  3. [langage] Suppression de doublon dans tableau
    Par LFC dans le forum Langage
    Réponses: 5
    Dernier message: 15/04/2004, 14h08
  4. Requête de suppression de doublons : besoin d'aide
    Par biocorp dans le forum Langage SQL
    Réponses: 3
    Dernier message: 27/01/2004, 17h04
  5. [LG]Suppression de doublons
    Par moustique31 dans le forum Langage
    Réponses: 5
    Dernier message: 20/12/2003, 21h03

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