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

PL/SQL Oracle Discussion :

Exécuter une procédure


Sujet :

PL/SQL Oracle

Vue hybride

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

    Informations forums :
    Inscription : Novembre 2007
    Messages : 29
    Par défaut Exécuter une procédure
    Bonjour à tous,

    Voilà j'ai installé Oracle Database 10g Express Edition Release 10.2.0.1.0 et après avoir créer une procédure avec des paramètres, je voudrais l'exécuter mais je n'y arrive pas. Pourtant je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    call reserver(10, 1, TO_DATE('2006/08/06', 'YYYY/MM/DD'),TO_DATE('2006/08/26','YYYY/MM/DD'));
    voici le corps de la procedure :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
     
    create or replace procedure reserver(v voiture.idv%type, 
     
    			  e employe.ide%type, 
     
                              jd reservation.jourDebut%type, 
     
    			  jf reservation.jourFin%type) 
     
    is
     
    	idr reservation.idr%type;
     
    	periodeinvalide exception;
     
            pragma exception_init (periodeinvalide ,-02290);
     
     
     
    	cleetrangereinvalide exception;
     
            pragma exception_init (cleetrangereinvalide ,-02291);
     
    begin
     
    	select count(*) into idr from reservation;
     
    	insert into reservation values(idr+1, jd, jf, v, e);	
     
     
     
    exception
     
    		when  periodeinvalide  then
     
    			raise_application_error (-20111, 'la période saisie est invalide');
     
    		when  cleetrangereinvalide then
     
    			raise_application_error (-20111, 'clé étrangere invalide');
     
     
     
     
     
     
     
    end reserver;

    Merci beaucoup


    Flo62

  2. #2
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Erreur ? Outils ?

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    29
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 29
    Par défaut
    je fais ca avec apex.

    mon erreur est :

    "ORA-00911: caractère non valide"

    merci

    Flo62

  4. #4
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    CALL est une commande SQL*Plus, me semble-t-il. A voir si cela fonctionne avec APEX.

    Sous SQL*Plus, ta syntaxe semble bonne.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    29
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 29
    Par défaut
    yes, car j'utilise sql*plus à mon université et ca marche mais chez moi j'utilise apex donc je sais pa trop comment je pourrais faire. Si c'est une question de syntaxe, il devrait bien y avoir une équivalence non ?


    Flo62

  6. #6
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Tu peux toujours faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    begin
      reserver(10, 1, TO_DATE('2006/08/06', 'YYYY/MM/DD'),TO_DATE('2006/08/26','YYYY/MM/DD'));
    end;
    /

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

Discussions similaires

  1. [PEAR][MDB2] Exécuter une procédure stockée
    Par mikedavem dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 06/01/2007, 09h33
  2. Réponses: 9
    Dernier message: 18/10/2006, 11h18
  3. Réponses: 1
    Dernier message: 26/07/2006, 11h23
  4. Une seule instance de l'appli et exécuter une procédure
    Par Manic dans le forum API, COM et SDKs
    Réponses: 11
    Dernier message: 08/03/2006, 11h52
  5. [Oracle] Exécuter une procédure PL/SQL en PHP?
    Par Cerberes dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 25/02/2005, 14h11

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