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 :

Update d'une table à partir des données d'une autre


Sujet :

Langage SQL

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Avril 2008
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Update d'une table à partir des données d'une autre
    Bonjour à tous,

    Je suis en train de faire la migration d'une base que je n'ai pas conçu.

    A la migration, je galère pas mal pour un truc que je pensais simple. Voici le souci :

    J'ai 2 tables :
    - T_organismes qui contient les différents organismes auquel je fait appel pour des formations.
    Elle contient 2 colonnes : 'num_organisme' qui est sa clé primaire et 'nom' qui est le nom de l'organisme

    - T_formations qui contient la liste des formations dispensées par ces organismes.
    Elle contient 2 colonnes : 'organisme' qui contient le nom de l'organisme et num_organisme qui pour l'instant ne contient rien mais qui devrait contenir le ' num_organisme' associé.

    Voici le problème : Comment remplir la colonne 'num_organisme' de la table T_formations avec le num_organisme de T_organisme en faisant la jointure entre 'nom' et 'organisme'

    Voici la requête que j'ai faite et qui ne fonctionne pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     UPDATE  T_Formations 
    SET  num_organisme =  
        (SELECT distinct T_organismes.num_organisme 
        FROM T_organismes    INNER JOIN  T_formations 
                    ON T_organismes.nom = T_formations.organisme)
    Pour éviter le distinct, j'ai également essayé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     UPDATE    T_Formations
    SET          T_Formations.num_organisme =
     
                            (SELECT     T_organismes.num_organisme
                            FROM          T_organismes, T_formations
                            WHERE T_organismes.nom =T_formations.organisme)
    J'ai le message d'erreur suivant : "L'operation doit utiliser une requete qui peut être mise à jour"

    Je réalise cette migration d'access 2000 vers access 2000 mais en passant par le DTS de SQL server 2000

    L'aide d'access me renvoit à une erreur de ce type :

    "Vous avez essayé d'exécuter une requête qui tente de mettre à jour un champ non modifiable. Par exemple, la requête a été créée de façon telle que vous essayez de mettre à jour un champ du côté un d'une relation un-à-plusieurs."

    C'est effectivement une relation de 1 à plusieurs mais c'est le coté plusieurs que j'essaye de mettre à jour.

    Merci d'avance,

    Grégory

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 098
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 098
    Points : 28 409
    Points
    28 409
    Par défaut
    Et comme ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    UPDATE  T_Formations 
    SET     num_organisme =  
            (   SELECT  T_organismes.num_organisme 
                FROM    T_organismes     
                ON      T_organismes.nom = T_formations.organisme
            )
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    58
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 58
    Points : 61
    Points
    61
    Par défaut
    Salut,

    fait comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    UPDATE  T_Formations
    SET T_Formations.num_organisme = T_organismes.num_organisme
    FROM T_organismes 
    WHERE T_organismes.nom = T_formations.organisme
    @+

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/03/2015, 10h33
  2. Réponses: 9
    Dernier message: 02/01/2014, 11h21
  3. Réponses: 2
    Dernier message: 17/01/2010, 18h09
  4. Réponses: 3
    Dernier message: 15/10/2008, 09h24
  5. Réponses: 2
    Dernier message: 15/06/2005, 17h32

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