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 :

Execution d'une procedure stockée ds un script pl-sql


Sujet :

Oracle

Vue hybride

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 49
    Par défaut Execution d'une procedure stockée ds un script pl-sql
    Bonjour
    Alors que je fais mes débuts en programmation pl-sql (après avoir suivi un cours) , je dois exécuter une procédure stockée
    dans un script pl_sql dont voici un extrait pour simplifier :

    DECLARE
    w_requete varchar2(1000);

    BEGIN
    DBMS_OUTPUT.PUT_LINE('DEBUG - Je suis passé par là');
    execute MA_PROC;
    END;


    Et voila ce que j'ai comme message
    execute MA_PROC;
    *
    ERREUR à la ligne 8 :
    ORA-06550: line 8, column 10:
    PLS-00103: Encountered the symbol "MA_PROC" when expecting one of the
    following:
    := . ( @ % ; immediate
    The symbol ":=" was substituted for "MA_PROC" to continue.


    J'ai l'impression que c'est la commande execute qui pose problème alors que ça fonctionne bien sous sqlplus ou sql-developpeur

    Alors si quelqu'un pouvait me dire (je continue tout de mêm à chercher)
    Merci à tous

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    En effet, supprimez le EXECUTE qui est une commande SQL*Plus et non PL/SQL et ça devrait marcher.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 49
    Par défaut
    Ok c'est bon mais j'ai un problème car je dois généré la requete (enfin l'exécution de cette proc en dynamyque puis l'exécuter avec execute dynamique (car je charge le nom du schéma en dynamique)
    w_requete := schemaMaj||'.MA_PROC'; (schemaMaj est une varaible alimentée auparavant)
    DBMS_OUTPUT.PUT_LINE ('requete a exécuter : '||w_requete);
    execute immediate w_requete;


    Et voilà l'injure !

    requete a exécuter : MON_SCHEMA.MA_PROC
    DECLARE
    *
    ERREUR à la ligne 1 :
    ORA-00900: invalid SQL statement
    ORA-06512: at line 21


    Alors que si j'excute l'instruction MON_SCHEMA.MA_PROC directement dans mon script PL SQL ça fonctionne
    j'ai le message suivant :
    Procédure PL/SQL terminée avec succès.

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    Essayez plutôt:

    BEGIN
    mon_schema.ma_proc;
    END
    Mais pour changer dynamiquement de schéma vous pouvez aussi utiliser:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER SESSION SET CURRENT_SCHEMA = mon_schema;
    et ne pas préfixer les objets par le nom du schéma.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 49
    Par défaut
    Ca marche
    Merci

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 49
    Par défaut
    c est la version 9i
    En fait le nom de mes schemas à mettre à jour, je les récupère dans une table d'un schéma X (disons d'administration) via un curseur. Ce qui fait que je peux avoir 1 à n schema sur lesquels je dois exécuter cette procédure en fonction d'un certain nombre de critères.
    A priori le dynamique dans une boucle est la seul solution pour automatiser

    Pour un début en pl sql , c'est formateur
    En tout ca marche, merci à tous

  7. #7
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    quelle version ?

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

Discussions similaires

  1. [VB.NET] Progress Bar et l'execution d'une procedure stockée
    Par messi1987 dans le forum Débuter
    Réponses: 4
    Dernier message: 19/03/2014, 23h22
  2. Réponses: 5
    Dernier message: 10/03/2014, 18h02
  3. Arreter l'execution d'une procedure stockée asynchrone
    Par Naruto_kun dans le forum Langages
    Réponses: 1
    Dernier message: 10/12/2013, 09h00
  4. Réponses: 0
    Dernier message: 23/11/2009, 17h05
  5. [SQL-Server] Execution d'une procedure stockée SQL Serveur depuis PHP.
    Par gregb34 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 04/05/2006, 01h06

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