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

Administration Oracle Discussion :

supprimer plan exécution


Sujet :

Administration Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2010
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2010
    Messages : 66
    Par défaut supprimer plan exécution
    Bonjour

    comment supprimer les plan d'exécution des requêtes ????

    Merci

  2. #2
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Les supprimer d'où ?? Et dans quel but ?

    Par ailleurs, il faut systématiquement indiquer votre version d'Oracle ; c'est un élément essentiel pour une réponse adaptée.

  3. #3
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2010
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2010
    Messages : 66
    Par défaut
    - j'utilise oracle 11g

    - je veux les supprimer de la cache

    - le but : pour que l’optimiseur de requêtes n'utilise pas les plan d'exécutions existants et créé un nouveau plan d’exécution pour chaque requête qui tient compte de la présence de nouveaux index.

    ( ça entre dans un cadre expérimental pour une évaluation de performance )

    Merci

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par CssFaxien Voir le message
    - le but : pour que l’optimiseur de requêtes n'utilise pas les plan d'exécutions existants et créé un nouveau plan d’exécution pour chaque requête qui tient compte de la présence de nouveaux index.
    Ce point là m'échappe : ça se passe déjà comme ça par défaut !

    Mais peut-être que ceci vous intéresse (V11) : ça permet de supprimer un curseur et ses plans associés du cache.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select address, hash_value from v$sqlarea where sql_text = 'select * from dept';
     
    ADDRESS HASH_VALUE
    -------- ----------
    2671F27C 3599690174
     
    exec dbms_shared_pool.purge('2671F27C,3599690174','C');

  5. #5
    Membre expérimenté Avatar de Ahmed AANGOUR
    Homme Profil pro
    DBA Oracle
    Inscrit en
    Janvier 2010
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : DBA Oracle

    Informations forums :
    Inscription : Janvier 2010
    Messages : 139
    Par défaut
    Bonjour,

    J'ai écris un article il y'a 2 mois sur ce sujet:
    http://ahmedaangour.blogspot.com/201...ared-pool.html

  6. #6
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2010
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2010
    Messages : 66
    Par défaut
    Citation Envoyé par Ahmed AANGOUR Voir le message
    Bonjour,

    J'ai écris un article il y'a 2 mois sur ce sujet:
    http://ahmedaangour.blogspot.com/201...ared-pool.html
    Merci Mr Ahmed

  7. #7
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2010
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2010
    Messages : 66
    Par défaut
    oui en principe c'est par défaut . j'ai mal expliqué
    lorsque j’exécute ma requête pour la première foi elle prend un temps de réponse 14 seconde et pour la deuxième foi 3 s .
    alors pour faire des comparaison je pense qu'il faut supprimer les plan d'exécution de la cache pour avoir des résultats significatifs .

    Merci

  8. #8
    Membre expérimenté Avatar de Ahmed AANGOUR
    Homme Profil pro
    DBA Oracle
    Inscrit en
    Janvier 2010
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : DBA Oracle

    Informations forums :
    Inscription : Janvier 2010
    Messages : 139
    Par défaut
    Citation Envoyé par CssFaxien Voir le message
    oui en principe c'est par défaut . j'ai mal expliqué
    lorsque j’exécute ma requête pour la première foi elle prend un temps de réponse 14 seconde et pour la deuxième foi 3 s .
    alors pour faire des comparaison je pense qu'il faut supprimer les plan d'exécution de la cache pour avoir des résultats significatifs .

    Merci
    Il y'a de fortes chances qu'à la 2ème exécution les données à récupérer sont déjà dans le cache et donc la requête est plus rapide car pas d'accès disque à faire.
    Pour en être sûr, vous pouvez exécuter votre requête sous SQLPLUS comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    ALTER SESSION SET STATISTICS_LEVEL=ALL;
    SET LINES 500
    SET PAGES 500
    <EXECUTEZ ICI VOTRE REQUETE>
    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_CURSOR(null,null,'ALLSTATS LAST'));
     
    <EXECUTEZ ICI VOTRE REQUETE une 2ème fois>
    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_CURSOR(null,null,'ALLSTATS LAST'));
    Faites nous parvenir ensuite les 2 plans générés.

  9. #9
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par CssFaxien Voir le message
    lorsque j’exécute ma requête pour la première foi elle prend un temps de réponse 14 seconde et pour la deuxième foi 3 s .
    alors pour faire des comparaison je pense qu'il faut supprimer les plan d'exécution de la cache pour avoir des résultats significatifs
    Comme Ahmed le suggère, c'est un effet de cache au niveau des données, et non au niveau du code SQL.

    S'il y a quelque chose à purger, ce sont donc les données des tables et index touchés par votre requête.
    Pour ça, je ne connais aucune méthode suffisamment sélective.
    ALTER SYSTEM FLUSH BUFFER_CACHE, ou la mise hors ligne momentanée du tablespace sont bien trop globaux.

    Notre ami Tom Kyte a une autre vision de la chose : ne surtout pas chercher à vider le cache de données, mais exécuter la requête plusieurs fois et faire la moyenne des temps.

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

Discussions similaires

  1. Interprétation d'un plan exécution d'une requete
    Par kochfet dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 30/05/2014, 14h32
  2. [11gR2] Réel plan exécuté dans le passé
    Par tropiko dans le forum Administration
    Réponses: 4
    Dernier message: 16/10/2013, 12h59
  3. Réponses: 7
    Dernier message: 09/11/2008, 22h33
  4. [EXPLAIN PLAN] Exécution de la requête
    Par tux2005 dans le forum Oracle
    Réponses: 3
    Dernier message: 02/10/2007, 17h29
  5. Supprimer l'exécutable d'un processus
    Par 0v3rb1t dans le forum Windows
    Réponses: 6
    Dernier message: 29/05/2007, 09h11

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