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 :

Mise à jour d'occurences de table après ajout de champ


Sujet :

Langage SQL

  1. #1
    Membre actif
    Inscrit en
    Décembre 2007
    Messages
    528
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 528
    Points : 211
    Points
    211
    Par défaut Mise à jour d'occurences de table après ajout de champ
    Bonjour,

    j'ai deux tables (tblfiches et tblressources) dont voici les structures :

    tblfiches
    numfiches
    ...
    ...
    iduser

    et

    tblressources
    numressources
    numfiches
    ...
    ...

    Pour des besoins d'exportation je viens d'ajouter le champ iduser à la table tblressources. Et comme tblfiches contient déjà des milliers d'enregistrements et que numfiches est un numéro unique, je souhaiterai faire un update sur tblressources de telle sorte que chaque occurrence du nouveau champ iduser soit le même que celui du iduser de tblfiches par rapport à numfiches.

    Ceci est-il correct s'il vous plaît?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE tblressources SET R.iduser = F.iduser FROM tblfiches F, tblressources R WHERE F.numfiches = R.numfiches;
    Je n'ai pas encore testé la requête de peur qu'altérer ma base de données.

    Merci d'avance.

    Cordialement.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    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 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Cette structure de requête ne sera pas prise en charge par la plupart des SGBD.

    Pour rester conforme à la norme, tu peux plutôt exécuter ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    UPDATE  tblressources   rsc
    SET     rsc.iduser =
            (   SELECT  fch.iduser
                FROM    tblfiches   fch
                WHERE   fch.numfiches = rsc.numfiches
            )
    WHERE   EXISTS
            (   SELECT  NULL
                FROM    tblfiches   fch
                WHERE   fch.numfiches = rsc.numfiches
            )
    ;
    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 actif
    Inscrit en
    Décembre 2007
    Messages
    528
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 528
    Points : 211
    Points
    211
    Par défaut
    Bonjour et Merci al1_24 pour votre précieuse aide. je n'ai pas encore testé mais je le ferai dès que je serais devant mon serveur. Par contre je souhaiterai vous soumettre une doléance. Pouvez-vous m'expliquer la dernière partie de votre requête s'il vous plaît (WHERE EXISTS...)?

    Merci d'avance.

    Cordialement.

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    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 080
    Points : 30 802
    Points
    30 802
    Par défaut
    La clause WHERE de cette requête sert à restreindre les mises à jours aux seules lignes de tblressources pour lesquelles une correspondance est trouvée dans la table tblfiches. Si elle est oubliée, la valeur de tblressources.iduser serait mise à NULL si une correspondance n'est pas trouvée, ce qui n'est peut-être pas le but recherché

    J'ai oublié de préciser que cette requête ne fonctionne qu'à la condition que la sous-requête sur tblfiches ne retourne pas plus d'une ligne pour chaque numfiches.
    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.

  5. #5
    Membre actif
    Inscrit en
    Décembre 2007
    Messages
    528
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 528
    Points : 211
    Points
    211
    Par défaut
    OK. Merci beaucoup. Je vais tester et certainement revenir pour donner le résultat.

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/04/2007, 20h19
  2. Mise à jour quotidienne d'une table via fichier texte
    Par chooky97150 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 31/08/2006, 22h00
  3. Mise à jour automatique d'une table access via un .xls
    Par infratunes dans le forum Access
    Réponses: 4
    Dernier message: 05/04/2006, 18h33
  4. [IB6] : Faire la mise à jour de tout les pc après un update
    Par tipiweb dans le forum Bases de données
    Réponses: 4
    Dernier message: 23/03/2006, 18h42
  5. Mise à jour d'une une table sql depuis table importée
    Par Yohann_x dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 09/03/2006, 11h43

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