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 :

Hint dans une boucle for


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 18
    Par défaut Hint dans une boucle for
    bonjour,
    --> sous oracle 11g
    je me pose la question suivante :

    un simple select avec un hint qui parallélise en ajoutant 2 thread.
    le plan d'exécution est correct.
    la requête émet bien les 2 PID.

    Sauf que lorsque je mets cela dans une boucle, on ne voit pas les process.

    exemple : le select standart :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select /*+ paralell (tm 2) */ * from data_full tm;

    exemple : la boucle :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for test in (select /*+ paralell (tm 2) */ * from data_full tm) 
     
    loop
     
    end loop;

    pouvez vous m'expliquer pourquoi je ne peux pas utiliser ma parallélisation, ni gérer les threads dans ma boucle ?
    Merci pour votre retour

  2. #2
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    Je pense que la parallélisation ne s'applique qu'au méthode ensembliste et par conséquent n'est pas viable dans une boucle.
    La partie SELECT doit être parallélisée mais en aucun la boucle qui est séquentielle

  3. #3
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

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

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611

  4. #4
    Membre Expert

    Homme Profil pro
    Inscrit en
    Mars 2010
    Messages
    536
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 536
    Par défaut
    Le hint parallel n'oblige pas Oracle de s'exécuter en parallèle. Il autorise simplement le CBO à considérer le coût de l'exécution de votre select en parallèle
    Une exécution en série peut s'avérer moins couteuse qu'une parallélisation conduisant ainsi le CBO à préférer l'exécution en série.

    http://jonathanlewis.wordpress.com/2...7/hints-again/

    Il y a quoi comme traitement dans la loop?

    Et comment êtes vous arrivé à avoir le plan d'exéction

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 18
    Par défaut
    Merci pour vos explications.


    Mohamed, il y a des insert dans ma boucle (limités par paquets).

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Février 2010
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 412
    Par défaut Pour les inserts
    Alors penchez vous du cote du bulk collect et du forall

Discussions similaires

  1. multi ouverture de la console dans une boucle for
    Par jamesleouf dans le forum C++
    Réponses: 2
    Dernier message: 16/03/2006, 21h26
  2. Shell - Erreur dans une boucle for
    Par claralavraie dans le forum Linux
    Réponses: 4
    Dernier message: 11/01/2006, 13h45
  3. Problème avec une DLL dans une boucle For
    Par BraDim dans le forum Langage
    Réponses: 5
    Dernier message: 20/09/2005, 12h22
  4. [batch] incrémentation dans une boucle for
    Par bart64 dans le forum Scripts/Batch
    Réponses: 4
    Dernier message: 08/09/2004, 20h05
  5. Réponses: 3
    Dernier message: 06/07/2004, 10h21

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