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

Oracle Discussion :

[Oracle 10g] Paralléliser du code PL/SQL


Sujet :

Oracle

  1. #1
    Yoh
    Yoh est déconnecté
    Membre du Club
    Inscrit en
    Juillet 2002
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 57
    Points : 46
    Points
    46
    Par défaut [Oracle 10g] Paralléliser du code PL/SQL
    Bonjour,

    Je recherche, pour le moment vainement, un moyen de paralléliser l'exécution de code PL/SQL packagé.

    Je m'explique :
    (1) J'ai plein de packages compilés sous Oracle.
    (2) J'ai un package particulier compilé lui aussi, qui fait une tâche particulière sur le serveur (écriture sur disque, etc...).

    Les packages (1) appellent tous le package (2), très souvent.
    Le package (2), en fonction des ressources du serveur, peut ralentir l'exécution des autres packages (1).

    C'est pourquoi je chercher à "paralléliser" (si le terme est bon) tout ce que fait le package (2) de sorte à ce que les packages (1) n'en soient jamais ralentis.

    Si, à défaut de m'aider techniquement, vous pouvez m'orientez dans la bonne direction, je vous en serais très reconnaissant.

    Merci,
    Yoh

  2. #2
    Expert éminent sénior 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
    Points : 11 252
    Points
    11 252
    Par défaut
    C’est quoi votre problème en fait ? Avez-vous un exemple à nous proposer pour qu’on puisse analyser ?
    Le système d’exploitation s’occupe très bien de ce que vous demandez : gestion de l'accès concurrent aux ressources du système.

  3. #3
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Bonjour,
    Le PL/SQL d'une session ne s'exécutera pas sur plusieurs CPU en parallèle.
    Il est par contre possible d'utiliser dbms_job pour lancer un job en background et dbms_loc (par exemple) pour se synchroniser.
    Cordialement,
    Franck.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

  4. #4
    Membre expérimenté Avatar de ojo77
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Décembre 2010
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2010
    Messages : 680
    Points : 1 597
    Points
    1 597
    Par défaut
    Bonjour,

    Si n procédure "pp" de (1) appellent une procédure "pf" de (2) alors cette procédure "pf" est automatiquement parallélisée n fois, il y a en effet une instanciation de "pf" pour chaque "pp".

    Par contre individuellement chaque procédure "pp" ou "pf" se déroule linéairement.

    Votre problème est-il d'accélérer "pf" en y introduisant du parallélisme (ce qui n'est pas possible directement) ou de rendre la procédure "pf" asynchrone de manière à ce qu'elle ne perturbe pas le déroulement de "pp" ?

Discussions similaires

  1. Réponses: 3
    Dernier message: 28/01/2010, 09h13
  2. [Oracle 10g] Retrancher 2 lignes en SQL
    Par david71 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 25/09/2008, 12h54
  3. Oracle 10G xmlType code SQL
    Par angeVirtuel dans le forum SQL
    Réponses: 0
    Dernier message: 19/09/2007, 10h14
  4. [SQL-Server] traduire un bout de code pour oracle en bout de code pour SQL SERVER
    Par teen6517 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 05/06/2007, 09h47
  5. [Oracle 10g]probleme avec une requette sql
    Par ragasy29 dans le forum SQL
    Réponses: 6
    Dernier message: 02/05/2007, 13h45

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