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

SQL Firebird Discussion :

Mise à jour d'une table avec une autre


Sujet :

SQL Firebird

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    172
    Détails du profil
    Informations personnelles :
    Âge : 83
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2002
    Messages : 172
    Points : 101
    Points
    101
    Par défaut Mise à jour d'une table avec une autre
    Bonjour,
    ce sujet est longuement traité dans les exemples trouvés en recherchant "Singleton" pourtant je ne trouve pas la solution pour le problème que j''expose ci-dessous.
    Soit une table
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE TR_GRADE_GRD (
        GRD_ID    D_ID NOT NULL /* D_ID = INTEGER */,
        GRD_DESC  D_GRADE NOT NULL /* D_GRADE = VARCHAR(32) */,
        GRD_NDX   D_ENT_COURT /* D_ENT_COURT = SMALLINT */
    qui sert de référence
    et une autre table, qui contient les données de l'utilisateur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TABLE T_GRADE_GRA (
        GRA_IND_ID   D_ID NOT NULL /* D_ID = INTEGER */,
        GRA_NOM      D_GRADE NOT NULL /* D_GRADE = VARCHAR(32) */,
        GRA_SECTION  D_SECTION NOT NULL /* D_SECTION = VARCHAR(32) */,
        GRA_DATE     D_DATE /* D_DATE = DATE */,
        GRA_NDX      D_ENT_COURT /* D_ENT_COURT = SMALLINT */
    Les index "GRA_NDX" et "GRD_NDX" sont identiques.
    Si l'utilisateur modifie dans la table de référence, l'intitulé des grades à savoir "GRD_DESC" je souhaiterais pouvoir modifier automatiquement "GRA_NOM" qui lui correspond.
    Or le code ci-dessous ne peut remplir ce rôle, puisqu'il renvoie plusieurs lignes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    update t_grade_gra gra
            set  gra.gra_nom = (select grd_desc from tr_grade_grd
           where gra.gra_ndx=grd_ndx)
    Il faudrait parcourir la table t_grade_gra ...pour la mettre à jour éventuellement...
    Voilà...j'ai besoin de vos lumières
    Merci,
    Lucien

  2. #2
    Membre éprouvé
    Avatar de Andry
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2002
    Messages
    1 164
    Détails du profil
    Informations personnelles :
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 164
    Points : 1 181
    Points
    1 181
    Par défaut
    Lucien,

    A mon avis l'utilisation d'un trigger After Update est plus approprié dans ton cas. Un essai à faire.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     IF (OLD.GRD_DESC <> NEW.GRD_DESC) THEN
    BEGIN
       UPDATE T_GRADE_GRA
           SET  GRA_NOM = NEW.GRD_DESC 
       WHERE
           GRA_NDX = NEW.GRD_NDX;
    A+

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    172
    Détails du profil
    Informations personnelles :
    Âge : 83
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2002
    Messages : 172
    Points : 101
    Points
    101
    Par défaut
    Merci Andry, je n'avais pas pensé à cette solution..
    Je viens d'essayer avec succès.
    C'est à la fois commode et élégant
    Trés bonne journée
    Lucien

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

Discussions similaires

  1. copier une table d'une BDD dans une table d'une autre BDD
    Par faniette dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/05/2013, 10h17
  2. [MySQL] requete dans une table avec une varible d'une autre table
    Par kogoi dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 03/11/2011, 15h24
  3. Réponses: 7
    Dernier message: 11/05/2010, 16h37
  4. Copier les enregistrements d'une table vers une table d'une autre DB
    Par karinette21 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 18/11/2008, 21h50
  5. Réponses: 6
    Dernier message: 30/08/2007, 16h47

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