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

Requêtes et SQL. Discussion :

Suppression doublons dans champ de table


Sujet :

Requêtes et SQL.

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Médecin responsable département information médicale
    Inscrit en
    Décembre 2011
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Médecin responsable département information médicale
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2011
    Messages : 30
    Points : 27
    Points
    27
    Par défaut Suppression doublons dans champ de table
    Bonjour,

    J'ai une table qui provient d'ORACLE par liaison ODBC, comportant une vingtaine de champs, dont un champ de numéro de dossier au format Texte, mais de type "111020567".
    Ce champ comporte fréquemment des numéros en double, voire en triple et même plus.
    Aucun de ces champs ne peut convenir pour créer une clé primaire dans la table provenant d'oracle.
    J'ai besoin d'avoir ce champ sans doublon.
    J'ai fait une copie de la structure de ma table et créer dans cette nouvelle table une clé primaire sur ce champ numéro de dossier.
    Ensuite je fais une requête "ajout" de l'ancienne table vers la nouvelle.
    Mon problème est que je ne retrouve pas tous mes numéros de dossier dans ma nouvelle table; il n'y a aucun doublon mais certains numéros de dossiers manquent.
    J'ai beau tourner le problème dans tous les sens je n'arrive à rien.
    Si quelqu'un avait l'immense bonté de me donner une piste je serais ravi.
    Avec mes remerciements

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 656
    Points : 34 368
    Points
    34 368
    Par défaut
    salut,

    le mieux serait d'avoir comme matière première de notre réflexion ton SQL d'ajout d'une table à l'autre

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Médecin responsable département information médicale
    Inscrit en
    Décembre 2011
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Médecin responsable département information médicale
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2011
    Messages : 30
    Points : 27
    Points
    27
    Par défaut Suppression doublons dans champ de table
    D'abord merci de t'intéresser à mon problème.
    Trouve ci-joint le code SQL de ma requête ajout.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO KALAM01_HRACTR_SANS_DOUBLONS
    SELECT KALAM01_HRACTR.*, *
    FROM KALAM01_HRACTR;
    Cordialement

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations forums :
    Inscription : Mars 2011
    Messages : 31
    Points : 32
    Points
    32
    Par défaut
    la meilleur façon serai de réaliser une procédure stocké (avec des CURSOR) pour régler ceci.

    ton bloc de programme doit procéder comme suit :

    - tu prend le 1er enregistrement, et puis tu compare ton champ num_dossier de cet enregistrement avec tous les enregistrements de la table,

    si il existe pour une 2éme fois
    tu supprimes tous les enregistrement qui contiennent ce num_dossier et puis tu insère cet enregistrement dans une nouvelle table (où tu va faire migrer ces données d'une façon a avoir une table sans doublons)

    sinon tu enregistre cet enregistrement dans la nouvelle table (toujours celle où tu va faire migrer ces données d'une façon a avoir une table sans doublons)

    j’espère que j'ai pu aider un peu

  5. #5
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 656
    Points : 34 368
    Points
    34 368
    Par défaut
    salut,

    je ne comprends pas le double *
    la requete simplifiée devrait être plutôt du style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO KALAM01_HRACTR_SANS_DOUBLONS
    SELECT *
    FROM KALAM01_HRACTR;

Discussions similaires

  1. [AC-2007] Fusion d’enregistrement avec suppression des doublons dans champs multivaleur
    Par Daniel-Gérald dans le forum VBA Access
    Réponses: 1
    Dernier message: 15/09/2011, 04h20
  2. Suppression doublon dans une table
    Par sat83 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 18/09/2008, 11h37
  3. Réponses: 3
    Dernier message: 24/02/2008, 21h34
  4. suppression doublons dans FlexGrid
    Par stef_445 dans le forum VB 6 et antérieur
    Réponses: 0
    Dernier message: 22/02/2008, 12h02
  5. Réponses: 11
    Dernier message: 09/03/2007, 12h10

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