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

Forms Oracle Discussion :

Forms 10g : implanter une fonction à l'aide d'un bouton


Sujet :

Forms Oracle

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    56
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 56
    Points : 25
    Points
    25
    Par défaut Forms 10g : implanter une fonction à l'aide d'un bouton
    Bonjour à tous, je vous explique mon probleme:
    J'ai 3 tables :
    etudiant (numetud,nom, prenom, datenaiss, civilite, patronyme, numinsee, adresse)
    inscription (numetud, codmod,dainsc,numtd)
    resultat (numetud,codmod,codexam,note)

    Je travail avec l'application Forms 10g et la table resultat contient 1 case (élément texte) qui est mention.

    J'ai créée une vue moyenne qui m'affiche la moyenne generale d'un etudiant grace à son numetud. Elle marche correctement est la moyenne s'affiche dans la colonne moy. Voici la vue:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    CREATE VIEW MOYENNE AS SELECT e.numetud, e.nom, r.codmod, 
    round(avg(r.note),2) moy FROM etudiant e, resultat r 
    WHERE e.numetud = r.numetud GROUP BY e.numetud, e.nom;
     J'ai créée la fonction mention d'un etudiant. Voici la fonction qui marche correctement:
    Puis , grace a la moyenne j'affiche la mention, voici son script:

    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
     
    CREATE OR REPLACE FUNCTION mention (v_numetud number, v_codmod number) RETURN varchar2 IS 
     
    v_moyenne decimal;
     
    begin
     
    SELECT round(avg(r.note),2) AS moy INTO v_moyenne FROM resultat r WHERE r.numetud = v_numetud
    AND r.codmod = v_codmod GROUP BY r.numetud, r.codmod;	
     
    	IF v_moyenne < 10 then
    		RETURN('Ajourne');
    	end IF;
     
    	IF  v_moyenne >= 10 AND v_moyenne < 12 then
    		RETURN('Passable');
    	end IF;
     
    	IF  v_moyenne >= 12 AND v_moyenne < 14 then
    		RETURN('Assez bien');
    	end IF;
     
    	IF  v_moyenne >= 14 AND v_moyenne < 16 then
    		RETURN('Bien');
    	end IF;
     
    	IF  v_moyenne >= 16 AND v_moyenne < 18 then
    		RETURN('Tres bien');
    	end IF;
     
    	IF  v_moyenne >= 18 AND v_moyenne < 20 then
    		RETURN('Excellent');
    	end IF;
     
    end;
    /
    Mon probleme est le suivant: j'ai créé un bouton "resultat de l'etudiant" et je veux qu'en inserant le numetud et le codmod de la table resultat et en clickan sur le bouton que j'obtienne la suite des infos sur l'etudiant (càdire codexam,note) ainsi que la mention qui saffiche automatiquement. Dans le code PL/SQL "When-Button-Pressed" du bouton j'ai mis le script suivant qu'il faut completer:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
        begin
    select numetud, codmod, codexam, note into :resultat.numetud, :resultat.codmod, :resultat.codexam, :resultat.note
    from resultat where numetud = :resultat.numetud and codmod= :resultat.codmod;      
     
     
    -- Par la suite je ne sais pas quel procédé utiliser pour faire intervenir la 
    -- moyenne et mention.
     
        exception
    when no_data_found then
    message('Invalid student id: please enter valid id.');
    raise form_trigger_failure;
    end;
    Faut-il mettre ma fonction mention dans une unité de programme ou seulement l'executer dans isqlplus ?

    Quequ'un à t-il une solution svp ?

    Merci pour votre aide.

  2. #2
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Ta fonction n'est pas correcte, elle doit sortir en erreur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE VIEW MOYENNE AS 
    SELECT e.numetud, e.nom, r.codmod, round(avg(r.note),2) moy
    FROM etudiant e, resultat r 
    WHERE e.numetud = r.numetud 
    GROUP BY e.numetud, e.nom;
    Il manque le group by codmod

    Ensuite, ta fonction mention fait un peu doublon avec ta vue moyenne : Tu refais un accès à la table resultat.
    Tu peux tout mettre dans la vue. Avec CASE tu peux faire tes tests de plage de moyenne sans problème dans ton SELECT.
    exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT (CASE WHEN dummy = 'Y' THEN 1 
    WHEN dummy = 'X' THEN 2
    ELSE 3 END) AS mention
    FROM dual
    Pour finir, une vue, c'est comme une table (sauf que rien n'est stocké physiquement dans la base). Tu fais un SELECT dessus
    exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT nom, codmod INTO ... 
    FROM MOYENNE 
    WHERE numetud = :block.numetud

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    56
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 56
    Points : 25
    Points
    25
    Par défaut
    Merci McM.
    Effectivement il y avait une erreur au niveau de la vue.
    Je vais tester la suite et je te dirai ce qu'il en est.

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    56
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 56
    Points : 25
    Points
    25
    Par défaut
    J'aimerai savoir comment affecter le resultat de ma fonction mention a la case "element texte" mention par exemple.
    Y a t-il par exemple un declencheur PL/SQL specifique à faire ?

  5. #5
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    et pourquoi pas un bloc basé sur la vue ? Sinon :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT tafonction INTO :BLOC.ITEM from dual;

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    56
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 56
    Points : 25
    Points
    25
    Par défaut
    Merci orafrance.
    Ma vue est bien basé et Mention ne l'est pas.
    Dans forms en inserant un numetud et en cliquant sur un bouton
    When-button-pressed, j'obtiens la moyenne de l'etudiant.
    Et j'ai dans le bloc de donnée Moyenne un element texte "mention" dont la fonction mention se trouve dans une unité de programme.
    J'aimerai faire appel a cette fonction qui me retourna "ajourné" ou "passable" ou ...

  7. #7
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    et pourquoi pas affecté la valeur dans WHEN-BUTTON-PRESSED... je ne comprends le souci là

  8. #8
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    56
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 56
    Points : 25
    Points
    25
    Par défaut
    C'est bon tout marche correctement.
    Merci orafrance il me manquer ta petite ligne de code.
    Bonne soiree

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

Discussions similaires

  1. Nom de form dynamique dans une fonction javascript
    Par voyageurdumonde dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 09/01/2013, 19h48
  2. appeler un windows.form.component depuis une fonction statique
    Par moshehayun dans le forum Windows Forms
    Réponses: 4
    Dernier message: 21/07/2009, 10h14
  3. Réponses: 4
    Dernier message: 02/11/2008, 02h59
  4. Réponses: 2
    Dernier message: 25/02/2008, 11h53
  5. [forms 10g] créer une LOV à partir de 2 champs liste
    Par lolafrite dans le forum Forms
    Réponses: 2
    Dernier message: 09/02/2007, 12h22

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