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 :

effectuer du pl/sql intéractif


Sujet :

PL/SQL Oracle

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    314
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 314
    Par défaut effectuer du pl/sql intéractif
    Bonjour,

    J'ai lu dans des documentations qu'il était impossible de faire du pl/sql intéractif. Cependant, j'ai pu apercevoir dans des posts antérieurs des moyens d'en faire.
    Je me suis inspiré de ces posts afin de faire une procédure avec des prompt à l'intérieur :
    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
    49
    50
    51
    52
    53
    54
    55
    56
     
    SET SERVEROUTPUT ON
    CREATE OR REPLACE PROCEDURE  modifier_entorg
       ( entorg_old  IN  organigramme%TYPE,
       	 entorg_new IN organigramme%TYPE
       )
    	IS
     
    	ent pers_orga_fonc.ENTORG%TYPE;
    	v_ent pers_orga_fonc.ENTORG%TYPE;
    	v_codagt pers_orga_fonc.CODAGT%TYPE;
    	v_coord pers_com.COORDONNEES%TYPE;
    	err_num NUMBER:=0;
    	err_msg varchar(1000);
     
     
    	BEGIN
     
    		dbms_output.enable(200000);
     
     
    	ACCEPT entorg_old PROMPT 'Saisir ancien entorg : '
     
     
     
    	DECLARE
    		ent pers_orga_fonc.ENTORG%TYPE;
    		ent := &entorg_old
     
    	Cursor c_curs is
    	select  pof.CODAGT, pof.ENTORG, pof.coordonnees
    	from pers_orga_fonc pof, personne p, pers_com pc, communication c
    	where pof.CODAGT=p.CODAGT
    	and pof.CODCOL_AGENT=p.CODCOL_AGENT
    	and p.CODAGT=pc.CODAGT
    	and p.CODCOL_AGENT=pc.CODCOL_AGENT
    	and pc.COORDONNEES=c.COORDONNEES
    	and pof.ENTORG='''||ent||'''; 
     
    	Open c_curs;
    	Loop
    		Fetch c_curs into v_codagt, v_ent, v_coord;
    		dbms_output.putline(v_codagt);
    	End Loop;
     
    	exception  
    	when others then
    		err_num := SQLCODE;
    		err_msg := SUBSTR(SQLERRM, 1, 1000);
    		dbms_output.put_line('Err num = ' || to_char(err_num) );
    		dbms_output.put_line('Err msg = ' || err_msg );
     
    	End; 
     
    END modifier_entorg;
    /
    Je reçois un message d'erreur me stipulant que ma procédure a été créée avec des erreurs de compilation, cependant, je n'ai pas d'affichage des messages d'erreurs.

    Quelqu'un aurait une idée ?

    Merci

    ps : pour info voici le lien que j'ai utilisé.
    http://www.developpez.net/forums/sho...=prompt+accept

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2004
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 36
    Par défaut
    bonjour,
    une fois ta procédure compilée, tu fais simplement un
    show errors

    Bonne journée

  3. #3
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ACCEPT entorg_old PROMPT 'Saisir ancien entorg : '
    ce n'est pas du PLSQL ça

  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
    Citation Envoyé par illegalsene
    J'ai lu dans des documentations qu'il était impossible de faire du pl/sql intéractif. Cependant, j'ai pu apercevoir dans des posts antérieurs des moyens d'en faire.
    Oui, il est impossible à proprement dit de faire du PL/SQL intéractif.

    Après, il existe des commandes SQL*Plus qui permette de créer une intéractivité (accept, prompt), mais elles ne peuvent pas être intégrées dans du PL/SQL.

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    314
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 314
    Par défaut
    ok.

    Donc si j'ai bien compris mon bloc accept prompt doit être sorti du bloc pl/sql ?

  6. #6
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    oui, c'est ça. PLSQL n'est pas interactif, SQLPLUS oui. Si tu n'employes pas sqlplus. alors pas de ACCEPT ni de PROMPT

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    314
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 314
    Par défaut
    justement j'emploie sqlplus

  8. #8
    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
    Dans ce cas il faut faire un script du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    accept maVar prompt "Valeur de la variable maVar : "
    begin
       dbms_output.put_line ('&maVar');
    end;
    /

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

Discussions similaires

  1. Effectuer une requête SQL en Pascal
    Par zpliz dans le forum Pascal
    Réponses: 6
    Dernier message: 26/04/2010, 14h02
  2. Réponses: 2
    Dernier message: 21/01/2010, 17h02
  3. Langage pour effectuer une requête SQL.
    Par slake13 dans le forum Langages de programmation
    Réponses: 3
    Dernier message: 19/11/2008, 13h22
  4. [adodbapi]Effectuer des requêtes SQL sur un fichier dbf
    Par Marie S. dans le forum Général Python
    Réponses: 5
    Dernier message: 22/10/2008, 12h57
  5. Comment effectuer une requette SQL depuis Excel vers une base MySQL ?
    Par Zorgloub dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 24/01/2008, 01h08

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