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 :

[Oracle] Optimisation sql


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 36
    Points : 24
    Points
    24
    Par défaut [Oracle] Optimisation sql
    Rebonjour!

    Bon, j'ai une requete qui prend des heures a s'executer et j'aimerais savoir s'il n'y a pas plus rapide:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT distinct TO_CHAR(ctr.matricule) || ';'
      FROM contrats ctr, individus ind
     WHERE ctr.matricule NOT IN (SELECT matricule
                                   FROM individus);
    Le but de cette requete est de lister tous les elements de la table contrats qui ne se trouvent pas dans la table individus.

    Si vous pouvez m'aider, c'est genial!

    Merci d'avance

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Points : 18 395
    Points
    18 395
    Par défaut
    Houla, joli produit cartésien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT TO_CHAR(ctr.matricule) || ';' as Matricule
    FROM contrats ctr
    WHERE NOT EXISTS (SELECT NULL FROM individus idv
                      WHERE ctr.matricule = idv.matricule)

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    de toute façon faudra parcourir toute la table individus donc le NOT EXISTS j'suis pas sûr qu'il donne grand chose

  4. #4
    Membre à l'essai
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 36
    Points : 24
    Points
    24
    Par défaut
    Merci vraiment sincerement pour ta réponse, les délais n'ont effectivement rien a voir. Je suis desolé de poser ces questions un peu betes des fois mais au boulot, ils ont décidé de me donner un projet de requetes sql sous oracle a faire et je n'y connais rien (c'est pas faute de leur avoir dit)... en plus, ca doit etre terminé pour demain... Super.

    J'aurais surement encore des questions a poser, désolé d'avance!

    Merci encore

  5. #5
    Membre à l'essai
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 36
    Points : 24
    Points
    24
    Par défaut
    Pour OraFrance:

    La requete que waldar m'a donné n'est donc pas bonne ou bien c'est juste en terme de délais que tu me dit que le Not Exist ne donne pas grand chose?

  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Points : 18 395
    Points
    18 395
    Par défaut
    C'est correct, c'est vrai que l'écriture EXISTS est plus propice dans le sens vrai que faux.
    Mais j'ai testé sur deux tables qui ont des volumétries significatives, le plan d'exécution est le même (et le temps de réponse est de deux secondes).
    Je précise que ID_TABLE_1 est la PK de TABLE_1 (pas d'index sur ID_TABLE_2), le SGBD est Oracle 11.1.0.6.

    NOT EXISTS
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select count(*) from TABLE_1
    where not exists (select null from TABLE_2 
                      where ID_TABLE_2 = ID_TABLE_1)
     
    -- Explain plan :
    SELECT STATEMENT  ALL_ROWSCost: 20,435  Bytes: 10  Cardinality: 1  			
    	4 SORT AGGREGATE  Bytes: 10  Cardinality: 1  		
    		3 HASH JOIN ANTI  Cost: 20,435  Bytes: 6,849,770  Cardinality: 684,977  	
    			1 INDEX FAST FULL SCAN INDEX (UNIQUE) ID_TABLE_1 Cost: 315  Bytes: 4,002,485  Cardinality: 800,497  
    			2 TABLE ACCESS FULL TABLE TABLE_2 Cost: 17,924  Bytes: 11,682,180  Cardinality: 2,336,436
    NOT IN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select count(*) from TABLE_1
    where ID_TABLE_1 not in (select ID_TABLE_2 from TABLE_2)
     
    -- Explain plan :
    SELECT STATEMENT  ALL_ROWSCost: 20,435  Bytes: 10  Cardinality: 1  			
    	4 SORT AGGREGATE  Bytes: 10  Cardinality: 1  		
    		3 HASH JOIN ANTI NA  Cost: 20,435  Bytes: 6,849,770  Cardinality: 684,977  	
    			1 INDEX FAST FULL SCAN INDEX (UNIQUE) ID_TABLE_1 Cost: 315  Bytes: 4,002,485  Cardinality: 800,497  
    			2 TABLE ACCESS FULL TABLE TABLE_2 Cost: 17,924  Bytes: 11,682,180  Cardinality: 2,336,436
    La seule différence est sur le hash join anti, qui est NA dans un cas et pas NA dans un autre, mais je n'ai aucune idée de la différence.

    Tant que j'y suis voici la méthode jointure externe.

    OUTER JOIN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    select count(*)
    from TABLE_1 left outer join TABLE_2
          on ID_TABLE_2 = ID_TABLE_1
    where PK_TABLE_2 is null
     
    -- Explain plan :
    Plan
    SELECT STATEMENT  ALL_ROWSCost: 21,006  Bytes: 16  Cardinality: 1  				
    	5 SORT AGGREGATE  Bytes: 16  Cardinality: 1  			
    		4 FILTER  		
    			3 HASH JOIN OUTER  Cost: 21,006  Bytes: 16  Cardinality: 1  	
    				1 INDEX FAST FULL SCAN INDEX (UNIQUE) ID_TABLE_1 Cost: 315  Bytes: 4,002,485  Cardinality: 800,497  
    				2 TABLE ACCESS FULL TABLE TABLE_2 Cost: 17,924  Bytes: 25,700,796  Cardinality: 2,336,436

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    Citation Envoyé par darkangel23fr Voir le message
    Pour OraFrance:

    La requete que waldar m'a donné n'est donc pas bonne ou bien c'est juste en terme de délais que tu me dit que le Not Exist ne donne pas grand chose?
    Je ne pensais pas que sur un parcours complet de la table tu aurais un gain de perf significatif, mais tant mieux si c'est le cas

  8. #8
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Points : 18 395
    Points
    18 395
    Par défaut
    Orafrance, vous avez du rater son produit cartésien dans son premier from, c'est celà qui plombe ses performances !

    Pour le NA, celà signifie Null Aware et c'est une méthode d'optimisation d'Oracle pour traiter les NOT IN justement.

    Un article ici : http://structureddata.org/2008/05/22...are-anti-join/

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

Discussions similaires

  1. [Oracle 9] [SQL] Optimisation d'une requete
    Par GAEREL dans le forum SQL
    Réponses: 11
    Dernier message: 16/02/2010, 16h43
  2. Réponses: 0
    Dernier message: 03/07/2008, 12h32
  3. Delphi -> Oracle : PL/SQL
    Par kribot dans le forum Bases de données
    Réponses: 4
    Dernier message: 15/06/2004, 14h18
  4. portage oracle pl/SQL -> PostGreSQL
    Par luta dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 26/05/2004, 12h40
  5. PHP + Oracle + PL/ SQL
    Par bchristo dans le forum SQL
    Réponses: 12
    Dernier message: 28/04/2004, 16h49

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