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 :

Dupliquer des données d'une table avec des requêtes le plus facilement possible.


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2017
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Août 2017
    Messages : 20
    Points : 18
    Points
    18
    Par défaut Dupliquer des données d'une table avec des requêtes le plus facilement possible.
    Bonjour à tous,

    Voici le MLD de ma BDD:

    -Table "Plan" : idPlan, version, ... A dupliquer
    -Table "Trou" : idTrou(PK), nomTrou, ... , idPlan (FK) A dupliquer
    -Table d'association "Active" : idTrou1(PK/FK), idTrou2(PK/FK) A dupliquer
    -Table "Site" : idSite (PK), ...
    -Table d'association "Surveille" : idSite(PK/FK), idPlan(PK/FK), ... A dupliquer
    -Table d'association "Record" : idSite(PK/FK), idPlan(PK/FK), idTrou(PK/FK), ... A dupliquer

    Je souhaite dupliquer un plan et le changer de version, mais je veux aussi dupliquer les trou qu'il possède (table trou) ainsi que ses sites (table surveille) et les record réalisé (table record).
    J'aimerai savoir s'il existe une requête SQL permettant de réaliser ce recopiage facilement ( en respectant les nouveaux id créés ).

    J'ai trouvé que je pouvais faire un :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    insert into plan 
       select * from plan where idPlan=1;
    Ce qui facilite et raccourcis mon code mais en réalisant cette requête sur les autres tables, j'obtiens par exemple pour la table trou : un trou qui possède l'idPlan du plan que j'ai choisi de dupliquer et non pas celui que je viens de dupliquer, ce qui pose gros problème puisque je vais ensuite modifier les trous (et que je ne souhaite pas modifier les trous de l'ancien plan). Comment régler ce problème ? Dois je réaliser un update sur toutes mes insertions et modifier idPlan(FK) dans la table trou? Ou existe t il un moyen plus simple de réaliser cela ?

    Par ailleurs, je ne vois pas trop comment faire pour dupliquer les données de ma table active en respectant les id des trous que je viens de créer. Des idées ?

    Pour information, j'utilise SQLite3.

    Merci pour le temps consacré sur mon problème.
    Bakamii.

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Au lieu de faire un SELECT *, il suffit de spécifier les colonnes (dans le INSERT INTO aussi), et de remplacer celles dont tu veux modifier la valeur par la valeur en question.

    Tatayo.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2017
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Août 2017
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Bonjour,

    Merci Tatayo pour ta réponse, elle m'a beaucoup aidé. J'ai finalement réussi ce que je voulais faire à l'aide de cet requête.

    Un petit exemple pour ceux qui lirait ce sujet :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    insert into plan (numero, version, date, nbLigne, nbColonne)
    select numero, 24, date, nbLigne, nbColonne
    from plan 
    where idPlan=1
    Ce code duplique donc la ligne de données ou l'idPlan est égale à 1 et modifie la donnée de la colonne 'version' par 24.

    Ensuite, après avoir stocké dans une variable(idPlanDuplique) l'id du plan résultant de la duplication, je réalise cette même requête pour les trou, en modifiant dans le select l'idPlan par idPlanDuplique et avec la clause 'where idPlan = x' (avec x égale à l'id du plan à dupliquer)

    Pour ce qui est du problème de la table d'association 'active', j'ai utilisé une HashMap<Integer,Integer> (Java) représentant
    -l'id du trou que je souhaite dupliquer en clé de ma Map
    -l'id du trou que j'ai créé suite à la duplication en valeur de ma Map
    Je remplis cette Map lorsque je duplique un trou(insert de nouveaux trous), je rentre (en clé) l'id du trou que je duplique et (en valeur) l'id du trou qui résulte de la duplication :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    map.put(idTrouADupliquer, idTrouDuplique);
    Du coup, avec l'id du trou à dupliquer je peux récupérer l'id du trou dupliqué.
    Je peux donc dupliquer ma table 'active' :
    Je réalise un select de ma table active et pour chaque couple de résultat (idTrou1,idTrou2) , j'insert dans ma table active les valeurs des clés du couple de résultat.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    int idTrou1New = map.get(idTrou1);
    int idTrou2New = map.get(idTrou2);
    insertTableActive(idTrou1New,idTrou2New);
    J'espère avoir été clair et compréhensible, je laisse le sujet ouvert pour d'éventuelles remarques sur la solution que j'ai utilisé pour dupliquer ma table d'association 'active'. Sans remarque d'ici la fin de la semaine je mettrai la discussion en résolue.

    Merci Tatayo !

    Bakamii.

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Plutôt que des boucles pour insérer ligne par ligne, vous pourriez insérer tout en une seule requête, et récupérer les identifiants générés grâce à la clause OUTPUT...
    Ce serait un peu plus compliqué, mais sans nul doute plus performant.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2017
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Août 2017
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Bonjour,

    Je ne connaissais pas cette clause. Elle me sera sûrement utile si j'ai des problèmes de performance et que je suis motivé, ou bien sur un autre projet.

    Merci

  6. #6
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2017
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2017
    Messages : 7
    Points : 13
    Points
    13
    Par défaut
    Attention à éviter le plus possible les insert into avec des *
    Sinon dès que tu modifies la structure d'une des 2 tables ça pète tout

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

Discussions similaires

  1. [AC-2003] Compléter une table avec des données d'autres tables
    Par Tchebichef dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 30/11/2012, 11h55
  2. [MySQL] Remplir une table avec des données déjà existantes
    Par Bruno.C dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 08/07/2008, 08h28
  3. Mise à jour des données d'une table avec un SELECT
    Par bouddine dans le forum Langage SQL
    Réponses: 0
    Dernier message: 20/05/2008, 16h36
  4. remplir une table avec des données aléatoire
    Par jamal_id dans le forum SQL
    Réponses: 3
    Dernier message: 17/10/2007, 10h11
  5. [MySQL] Ajouter des données dans une table avec la cmd update
    Par pierrot10 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 25/09/2007, 19h54

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