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 :

Ordre d'exécution requête update where exists


Sujet :

SQL Oracle

  1. #1
    Membre éclairé Avatar de ben.IT
    Homme Profil pro
    Inscrit en
    Janvier 2009
    Messages
    431
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Puy de Dôme (Auvergne)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 431
    Par défaut Ordre d'exécution requête update where exists
    Bonjour à tous,

    je veux mettre à jour les champs de la table 1 à partir de des champs de la table 2 avec une condition sur une date dans la table 1 afin de ne pas ramener trop d'enregistrement.
    pouvez vous me renseigner sur l'ordre de traitement dans la requête suivante :
    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
     
    UPDATE TABLE_1 T1
    SET (CHAMPS_1,CHAMPS_2)
    (
    SELECT CHAMPS_1, CHAMPS_2
    FROM TABLE_2 T2 
    where T2.NUM = T1.ID
    )
    Where exists
    (
    SELECT T2.CHAMPS_1, T2.CHAMPS_2
    FROM TABLE_2 T2, TABLE_1 T1 
    where T2.NUM = T1.ID
    AND T1.DATE_TRT < '16/11/11' AND T1.DATE_TRT > '01/10/11'
    )
    La clause exists est bien executée en premier puis l'update avec la sous requête de jointure uniquement pour les lignes ramenées par le exists ?

    merci d'avance,
    ben

  2. #2
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut !

    Oui, tout à fait. Par contre, je pense que ta requête n'est pas géniale : il ne faut pas refaire la jointure avec TABLE_1 dans tes sous-requêtes.

    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
     
    UPDATE TABLE_1 T1
    SET (CHAMPS_1,CHAMPS_2)
    (
    SELECT CHAMPS_1, CHAMPS_2
    FROM TABLE_2 T2 
    WHERE T2.NUM = T1.ID
    )
    WHERE EXISTS
    (
    SELECT T2.CHAMPS_1, T2.CHAMPS_2
    FROM TABLE_2 T2
    WHERE T2.NUM = T1.ID
    AND T1.DATE_TRT < '16/11/11' AND T1.DATE_TRT > '01/10/11'
    )
    (J'ai viré le "TABLE_1 T1" de ta requêtes EXISTS)

    Au passage, si tu es en Oracle 10g ou plus, tu peux utiliser MERGE.

  3. #3
    Membre éclairé Avatar de ben.IT
    Homme Profil pro
    Inscrit en
    Janvier 2009
    Messages
    431
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Puy de Dôme (Auvergne)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 431
    Par défaut
    Ok, merci de ta réponse.
    juste pour être bien sur :
    si la partie avec le where exists renvoie 100 lignes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    WHERE EXISTS
    (
    SELECT T2.CHAMPS_1, T2.CHAMPS_2
    FROM TABLE_2 T2
    WHERE T2.NUM = T1.ID
    AND T1.DATE_TRT < '16/11/11' AND T1.DATE_TRT > '01/10/11'
    )
    la partie update ne fera la jointure pour l'update qu'uniquement pour ces 100 lignes ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    UPDATE TABLE_1 T1
    SET (CHAMPS_1,CHAMPS_2)
    (
    SELECT CHAMPS_1, CHAMPS_2
    FROM TABLE_2 T2 
    WHERE T2.NUM = T1.ID

    ben

  4. #4
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Tout à fait

    (N'oublie pas le "=" après le SET )

  5. #5
    Membre éclairé Avatar de ben.IT
    Homme Profil pro
    Inscrit en
    Janvier 2009
    Messages
    431
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Puy de Dôme (Auvergne)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 431
    Par défaut
    merci.
    @ +,
    ben

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

Discussions similaires

  1. [MySQL] Problème requête UPDATE (WHERE)
    Par cedric.g dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 11/06/2012, 16h16
  2. [Hibernate][proxy] Problème exécution requêtes update et remove
    Par amadoulamine1 dans le forum Hibernate
    Réponses: 2
    Dernier message: 08/07/2011, 12h18
  3. [SQL] Requête UPDATE qui ne s'exécute pas avec PHP
    Par xplose dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 16/08/2007, 09h42
  4. Réponses: 5
    Dernier message: 10/07/2006, 12h05
  5. Ordre d'exécution de la requête
    Par raf_gug dans le forum Requêtes
    Réponses: 4
    Dernier message: 19/04/2006, 10h30

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