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

PostgreSQL Discussion :

Ajout de données sans duplication


Sujet :

PostgreSQL

  1. #1
    Membre actif

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2011
    Messages
    370
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2011
    Messages : 370
    Points : 251
    Points
    251
    Par défaut Ajout de données sans duplication
    Bonjour,

    Voici ce que je fais maintenant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Copy maj_fgd FROM '/home/Dump/MAJ_FGD.csv' DELIMITER ';' CSV HEADER;
    Je voudrais en fait n'ajouter que les données qui n'existent pas.

    Comment faire ?

    Voici à quoi ressemble ma table:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    CREATE TABLE banque_bic.maj_fgd
    (
      cib_absorbe character(5) NOT NULL, -- Code banque absorbe
      nom_banque_absorbe character varying(250) NOT NULL, -- Nom de la banque absorbe
      cib_absorbant character(5) NOT NULL, -- Code banque absorbante
      nom_banque_absorbant character varying(250) NOT NULL, -- Nom de la banque absorbante
      date_effet character(8) NOT NULL, -- Date d effet et donc de fin de validite du code absorbe
      CONSTRAINT maj_fgd_pkey PRIMARY KEY (cib_absorbe, cib_absorbant)
    )
    WITH (
      OIDS=FALSE
    );
    ALTER TABLE banque_bic.maj_fgd
      OWNER TO postgres;
    COMMENT ON TABLE banque_bic.maj_fgd
      IS 'Copie du Fichier des Guichets Domiciliataires';
    COMMENT ON COLUMN banque_bic.maj_fgd.cib_absorbe IS 'Code banque absorbe';
    COMMENT ON COLUMN banque_bic.maj_fgd.nom_banque_absorbe IS 'Nom de la banque absorbe';
    COMMENT ON COLUMN banque_bic.maj_fgd.cib_absorbant IS 'Code banque absorbante';
    COMMENT ON COLUMN banque_bic.maj_fgd.nom_banque_absorbant IS 'Nom de la banque absorbante';
    COMMENT ON COLUMN banque_bic.maj_fgd.date_effet IS 'Date d effet et donc de fin de validite du code absorbe';
    Cordialement,
    Vandman

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour,

    Chargez vos données dans une table temporaire, puis insérer dans la table destination à partir d'une requête d'insertion à partir d'une requête sur cette table temporaire, avec jointure externe sur la table destination, pour ne conserver que les lignes qui existent seulement dans la table temporaire.

    Euh, je suis clair, là ou pas ?
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    On peut aussi utiliser EXCEPT pour comparer les tables et faire le tri

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Ou encore attendre la version 9.5 de PostgreSQL (ou installer la version alpha 2 si vous êtes joueur, mais surtout pas sur un environnement de production), qui arrive avec une syntaxe INSERT qui permettra (un peu comme le MERGE sous Oracle) de n'insérer que ce qui n'existe pas...
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  5. #5
    Membre habitué

    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 101
    Points : 141
    Points
    141
    Par défaut
    Vosu pouvez aussi essayer avec une RULE voire un trigger à l'insertion

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE RULE "rule_bloquer_doublons" AS ON INSERT TO "ma_table"
      WHERE EXISTS(SELECT 1 FROM ma_table 
                    WHERE unique_col_1=NEW.unique_col_1 AND unique_col_2= NEW.unique_col_2)
    DO INSTEAD NOTHING;

Discussions similaires

  1. [WD17] Ajouter des données à partir d'un table sans clé prim
    Par hadaf dans le forum WinDev
    Réponses: 2
    Dernier message: 09/12/2013, 17h04
  2. Réponses: 2
    Dernier message: 08/09/2012, 12h09
  3. ajouter données sans supprimer données existantes
    Par grimat dans le forum Débuter
    Réponses: 1
    Dernier message: 04/01/2009, 21h42
  4. Ajouter des données Excel à une table SANS références?
    Par Miss Ti dans le forum VBA Access
    Réponses: 6
    Dernier message: 12/10/2007, 18h58
  5. Réponses: 4
    Dernier message: 14/05/2007, 10h50

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