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 :

Doublons dans une base a supprimer


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2021
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Janvier 2021
    Messages : 2
    Points : 5
    Points
    5
    Par défaut Doublons dans une base a supprimer
    Bonjour, j'ai une table à +3M d'enregistrement et pour travailler dessus j'aimerais enlever les doublons,(ARAEAN OU S'yTROUVE LES DOUBLONS)
    J'ai une table Out/EAN_VIDOM et j'ai ARACOD (clé primaire) et mes doublons dans ARAEAN il y aurais une requête pour supprimer tout ça ? Garder un exemplaire unique de chaque ARAEAN avec le ARACOD en tant que min

    J'ai utilisé le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    DELETE FROM out/EAN_VIDOM
    LEFT OUTER JOIN (
            SELECT MIN(ARACOD) as id, ARAEAN
            FROM OUT/EAN_VIDOM
            GROUP BY ARAEAN
        ) as t1 
        ON OUT/EAN_VIDOM.id = t1.id
    WHERE t1.id IS NULL

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    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 136
    Points : 38 561
    Points
    38 561
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    Exemple de solution

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    delete from ma_table TAB0
    where exists
         (select 1
          from ma_table TAB1
          where TAB1.ARAEAN = TAB0.ARAEAN
            and TAB1.ID     < TAB0.ID
         )
    Pour éviter que d'autres doublons apparaissent, il faut ensuite ajouter une contrainte UNIQUE sur la colonne ARAEN.
    Je suis surpris par la présence du caractère "/" dans le nom de la table, c'est un caractère réservé qui nécessite d'encadrer le nom par des crochets.
    Le plus simple est de ne pas utiliser les caractères et les mots réservés dans les noms d'objets.

    Attention : s'il y a un grand nombre de doublons et que l'identifiant TAB0.id fait l'objet de contraintes avec ON DELETE CASCADE dans d'autres tables, il peut y avoir un grand nombre de mises à jour

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

Discussions similaires

  1. Identifier les doublons dans une base
    Par End_Sub dans le forum Macros et VBA Excel
    Réponses: 212
    Dernier message: 22/01/2017, 13h36
  2. Comment réperer les doublons dans une base de données?
    Par Marc31 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 16/07/2015, 16h29
  3. [Débutant] Eviter les doublons dans une base access
    Par gilles_906 dans le forum VB.NET
    Réponses: 24
    Dernier message: 29/08/2011, 16h46
  4. [vbexcel]Comment supprimer les doublons dans une combobox?
    Par Mugette dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 24/11/2005, 11h12
  5. [MySQL] Supprimer une ligne afficher dans une base de donnée
    Par julienchpt dans le forum PHP & Base de données
    Réponses: 31
    Dernier message: 14/10/2005, 15h45

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