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 Oracle Discussion :

Jointure et modif


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2018
    Messages
    415
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2018
    Messages : 415
    Points : 40
    Points
    40
    Par défaut Jointure et modif
    Bonjour tout le monde,

    j'ai ma table principale : TRANSACT(W,X,Y,Z)

    J'ai une table : Table1(W,X,Y,Z) et j'ai besoin de récupérer le max(Y) depuis TRANSACT
    pour chaque ligne de table1 existante dans TRANSACT
    autrement :

    where table1.W= TRANSACT.W
    and table1.X = TRANSACT.W
    ....

    D'autre part j'ai une deuxième table : TABLE2(W,X,Y,Z,D)

    J'ai besoin de modifier (UPDATE) le champs D dans TABLE2 de telle sorte:

    D := max(Y) + X

    NB : (transact & table1 ont même structure)

  2. #2
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Bonjour,

    Tu donnes pas complètement les jointures entre les tables (surtout table2)

    J'ai fait un truc approchant, à toi de voir s'il faut rajouter des restrictions ou si ce n'est pas ce que tu souhaites

    Tu as noté
    where table1.W= TRANSACT.W
    and table1.X = TRANSACT.W
    Ce serait pas and table1.X = TRANSACT.X ?

    J'ai considéré que les jointures entre les tables sont sur W et X
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE TABLE2 t2
    set d = x + (SELECT MAX(t.y) FROM TRANSACT t, TABLE1 t1 WHERE t1.w = t.w AND t1.x = t.x AND t.w = t2.w AND t.x = t2.x)
    WHERE EXISTS (SELECT 1 FROM TRANSACT t, TABLE1 t1 WHERE t1.w = t.w AND t1.x = t.x AND t.w = t2.w AND t.x = t2.x)
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

  3. #3
    Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2018
    Messages
    415
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2018
    Messages : 415
    Points : 40
    Points
    40
    Par défaut
    merci pour votre réponse, mais c'est un peu basic !!

    ça doit être dans ce sens :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    MERGE INTO table O
    USING ( WITH CURSOR_A AS ( SELECT ....
                                FROM  ....
                               WHERE .... )
     
                 CURSOR_B AS ( SELECT ....
                                FROM  ....
                               WHERE ....)
     
            SELECT ......
            FROM CURSOR_A NATURAL JOIN CURSOR_B
     
    		WHERE ) D
     
       ON ( O. = D.  AND O.  = D. )
     WHEN MATCHED THEN 
     UPDATE SET ...

  4. #4
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par LandGreen Voir le message
    merci pour votre réponse, mais c'est un peu basic !!
    ça doit être dans ce sens :
    Si le résultat n'est pas celui escompté, alors il faut nous donner les structures exactes des tables, un jeu de données, et le résultat attendu.
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/01/2012, 10h14
  2. [phpmyedit] jointure et modification champs virtuel
    Par skeut dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 0
    Dernier message: 22/03/2011, 13h17
  3. modif requete avec jointure
    Par looping dans le forum Bases de données
    Réponses: 3
    Dernier message: 17/11/2008, 15h03
  4. Table avec jointure et modification
    Par guen dans le forum Modélisation
    Réponses: 5
    Dernier message: 02/04/2008, 22h06
  5. Réponses: 11
    Dernier message: 23/07/2002, 14h33

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