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 :

Exporter les données d'une table dans une table plus grande


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2012
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2012
    Messages : 52
    Points : 31
    Points
    31
    Par défaut Exporter les données d'une table dans une table plus grande
    Bonjour,

    Ma problématique est simple mais je n'arrive pourtant pas à trouver la bonne commande.
    Je possède une première table1 à X colonnes et une table2 à X+1 colonnes.
    En fait dans table2, j'ai une première colonne spécifique et les X dernières colonnes correspondent aux X colonnes de la table1 (même champs, même structure).
    Je voudrais donc exporter les données de ma table1 dans la table2 (la première colonne de la table2 ne doit pas être modifiée lors de l'import).

    Si je lance la commande suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO table2 SELECT * from table1
    J'ai l'erreur suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Column count doesn't match value count at row 1

    Si vous avez des idées....
    Merci!!

  2. #2
    Membre éclairé Avatar de Arkhena
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 552
    Points : 769
    Points
    769
    Par défaut
    Bonjour,

    Je pense que ça devrait marcher comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO table2 (col2, col3, ..., colX+1)
    SELECT * FROM table1
    ou alors


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO table2
    SELECT NULL, col1, col2, ..., colX FROM table1
    Cordialement,

    Arkhena
    A bove ante, ab asino retro, a stulto undique caveto

  3. #3
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Bonjour,

    Il faut détailler les colonnes (chose qui reste conseillé dans tous les cas)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO MaTableA (a,b,c,d,e)
    SELECT a,b,c,d,e FROM MaTableB
    ~ Lola ~

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 383
    Points
    18 383
    Par défaut
    Quelle est la relation entre les données de la première colonne et celles de la table1 ?

    Si vous avez déjà des données dans votre table2, ce n'est plus une insertion qu'il faut faire mais une mise à jour.

  5. #5
    Nouveau membre du Club
    Inscrit en
    Mars 2012
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2012
    Messages : 52
    Points : 31
    Points
    31
    Par défaut
    Citation Envoyé par lola06 Voir le message
    Bonjour,

    Il faut détailler les colonnes (chose qui reste conseillé dans tous les cas)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO MaTableA (a,b,c,d,e)
    SELECT a,b,c,d,e FROM MaTableB
    Oups, j'ai plus de 250 colonnes, pas d'autre moyen?


    Citation Envoyé par Waldar
    Quelle est la relation entre les données de la première colonne et celles de la table1 ?

    Si vous avez déjà des données dans votre table2, ce n'est plus une insertion qu'il faut faire mais une mise à jour.
    Non, ma table2 est vide au moment de l'import...

  6. #6
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Dans ce cas cette solution devrait être correcte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO MaTableA
    SELECT null, B.* FROM MaTableB B
    ~ Lola ~

  7. #7
    Nouveau membre du Club
    Inscrit en
    Mars 2012
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2012
    Messages : 52
    Points : 31
    Points
    31
    Par défaut
    Citation Envoyé par lola06 Voir le message
    Dans ce cas cette solution devrait être correcte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO MaTableA
    SELECT null, B.* FROM MaTableB B
    Super, ça marche avec ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO MaTableA
    SELECT null, B.* FROM MaTableB AS B
    Merci!!!

  8. #8
    Membre éclairé Avatar de Arkhena
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 552
    Points : 769
    Points
    769
    Par défaut
    Citation Envoyé par pierricktpt Voir le message
    Oups, j'ai plus de 250 colonnes, pas d'autre moyen?
    Selon le SGBD, vous pouvez construire votre requête en utilisant le catalogue de métadonnées.
    A bove ante, ab asino retro, a stulto undique caveto

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

Discussions similaires

  1. [Toutes versions] coller les données d'une plage d'une cellule dans une cellule d'une autre feuille[VBA]
    Par arthson dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 24/01/2012, 17h37
  2. [AC-2003] Lier les tables d'une Base1 dans une Base3 via une Base2
    Par ted the Ors dans le forum VBA Access
    Réponses: 0
    Dernier message: 30/12/2009, 11h58
  3. [POO] dans une classe, appeler une fonction dans une méthode
    Par arnaudperfect dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2007, 23h04
  4. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 10h13
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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