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

PL/SQL Oracle Discussion :

optimisation d'une req


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mars 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 86
    Par défaut optimisation d'une req
    Bonjour,

    Je cherche à optimiser la req 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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    INSERT INTO TABLE_RES a ( 
        id, nom, prenom1, prenom2, prenom3, date_inser1, date_inser2, date_inser3, ville, code_post, tel, email, flag, date_jour)  
            SELECT DISTINCT 
             f.id,
             f.nom,
             f.prenom,
             a.prenom,
             e.prenom,
             f.date_inser,
             a.date_inser – b.date_inser,
             e.date_inser – s.date_inser,
             f.ville, 
             f.code_post, 
             f.tel, 
             f.email, 
             ‘NE’, 
             to_date(datejour, ‘dd/mm/yyyy’)
     
            FROM 
            tab_src f, table2 a, table3 b, table4 e, table5 s 
            WHERE 
            e.id = s.id 
            AND f.code_ost in ('030', '040') 
            AND to_date(e.valuedate, 'dd/mm/yyyy') between datejour - 2 and datejour 
            AND a.id = b.id 
            AND a.dtvaleur between datejour - 2 and datejour 
     
            AND f.id = e.id 
            AND f.id = a.id  
            AND ((trunc(f.qte, 4) <> trunc(e.qte, 4)) 
                or (trunc(f.qte, 4) <> trunc(a.qte, 4)) 
               ) 
            AND (f.id) 
                NOT IN 
                (SELECT c.id 
                 FROM TABLE_RES c 
                 WHERE c.flag = 'NE');
    Merci pour vos req,

  2. #2
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    On n'est pas magicien, sans plan d'exécution on aura du mal à voir les éventuelles faiblesses.

  3. #3
    Membre expérimenté
    Avatar de (Benoit)
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    184
    Détails du profil
    Informations personnelles :
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 184
    Par défaut
    Bonjour,

    Sans le modèle de données, c'est pas évident

    Sinon je n'ai rien vu de choquant dans la requête que tu as posté.

  4. #4
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    tu peux essayer de remplacer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
            AND (f.id) 
                NOT IN 
                (SELECT c.id 
                 FROM TABLE_RES c 
                 WHERE c.flag = 'NE');

    Par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    NOT EXISTS (SELECT 1
    FROM TABLE_RES c 
    WHERE c.flag = 'NE'
       AND c.id = f.id)
    avec un index sur TABLE_RES(id,flag)

    Et éventuellement des indexes de fonction sur trunc(qte, 4) des tables concernées

Discussions similaires

  1. Optimisation d'une recherche et mise à jour
    Par gandf dans le forum C++Builder
    Réponses: 4
    Dernier message: 07/01/2005, 18h38
  2. Réponses: 17
    Dernier message: 03/12/2004, 11h17
  3. [Debutant] Optimisation d'une boucle
    Par Javatator dans le forum Langage
    Réponses: 3
    Dernier message: 25/10/2004, 18h50
  4. erreur au lancement d'une req Oracle (SP2-0552)
    Par etham dans le forum Administration
    Réponses: 5
    Dernier message: 16/04/2004, 16h23
  5. Réponses: 4
    Dernier message: 03/03/2004, 11h04

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