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 :

Récupérer plusieurs valeurs


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2007
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 18
    Par défaut Récupérer plusieurs valeurs
    bonjour,
    je recherche comment récuperer plus d'1 valeur en retour dans un package/package body sous Oracle developer 1.2.1 soit par function ou par cursor en PL/SQL.
    la déclaration objet n'est pas acceptée.
    exemple : à partir d'un code postal, valeurs retournées Departement, ville
    Merci de votre aide.

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Pourquoi ne pas créer une procédure avec 2 paramètres de type OUT ?

    Sinon, tu peux retourner un TYPE créer préalablement, cf http://forums.oracle.com/forums/thre...hreadID=428977

    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
    DECLARE
      TYPE t_myresult IS RECORD (myres1 number, myres2 number);
      myresult   t_myresult;
     
      x number := 10;
      y number := 3;
     
      FUNCTION myfunc (p_val1 IN NUMBER, p_val2 IN NUMBER) RETURN t_myresult IS
        v_res t_myresult;
      BEGIN
        v_res.myres1 := ROUND(p_val1 / p_val2);
        v_res.myres2 := p_val1 - (v_res.myres1 * p_val2);
        RETURN v_res;
      END;
    BEGIN
      myresult := myfunc(x,y);
      DBMS_OUTPUT.PUT_LINE('X='||x||'; Y='||y||'; X/Y='||myresult.myres1||' remainder '||myresult.myres2);
    END;

  3. #3
    Membre averti
    Inscrit en
    Janvier 2007
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 18
    Par défaut
    Merci pour la réponse, cela fonctionne.
    Mais pour inclure dans un package :
    je mets dans le package les déclarations de type et de function
    dans le body la function
    , je compile sans erreur, mais quand je je lance le select pour récupérer les valeurs, j'ai l'erreur :
    identificateur non valide
    j'ai du passer à coté de quelquechose ?

  4. #4
    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
    avec le code on pourra t'aider.

  5. #5
    Membre averti
    Inscrit en
    Janvier 2007
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 18
    Par défaut
    voici le code :
    la compilation du package se passe bien.
    je devrais utiliser un cursor plutot qu' une fonction ?

    merci de votre aide.

    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
    create or replace package P1 is
     
    --fonction Dept_ESO : retourne le n° de dept et le libelle de l'Etab
     
    type DeptEso is record ( Departement varchar2(2), Libelle_Etab varchar2(32)); 
     
    Function Dept_ESO (xEtab varchar2) return DeptEso;
     
    end P1;
     
     
     
     
     
     
    create or replace package body P1 is
     
    /*
    --=====Departement de l'ESO====
    */
     
    Function Dept_ESO (xEtab varchar2) return DeptEso is r DeptEso;
    begin
     select substr(mgadr.MGADR_CODPOS, 1, 2), 
            paesi.paesi_lib                 
     from paesi, paead, mgadr
     where paesi.paesi_codext = xEtab
     and paead.paesi_num = paesi.paesi_num
     and mgadr.mgadr_num = paead.mgadr_num;
     
    return r;
     
    end Dept_ESO;
     
    end P1;

  6. #6
    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
    Si tu n'as qu'une seule ligne, non, pas de curseur.
    Par contre un select en plsql doit toujours être into quelque chose.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    FUNCTION Dept_ESO (xEtab varchar2) RETURN DeptEso IS 
    r DeptEso;
    begin
     SELECT substr(mgadr.MGADR_CODPOS, 1, 2), paesi.paesi_lib                 
    into r.departement, r.Libelle_Etab
     FROM paesi, paead, mgadr
     WHERE paesi.paesi_codext = xEtab
     AND paead.paesi_num = paesi.paesi_num
     AND mgadr.mgadr_num = paead.mgadr_num;
     
    RETURN r;
     
    end Dept_ESO;

Discussions similaires

  1. Récupérer plusieurs valeurs d'une liste déroulante
    Par sicilianadev dans le forum Langage
    Réponses: 7
    Dernier message: 23/11/2008, 15h41
  2. Récupérer plusieurs valeurs
    Par loukoum82 dans le forum SQL
    Réponses: 3
    Dernier message: 21/09/2007, 16h07
  3. récupérer plusieurs valeurs dans un champ hidden
    Par karimphp dans le forum Langage
    Réponses: 3
    Dernier message: 07/12/2006, 17h13
  4. [SQL] Récupérer plusieurs valeurs
    Par bogsy15 dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 09/08/2006, 10h46
  5. Réponses: 16
    Dernier message: 19/07/2006, 00h16

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