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

SQL Oracle Discussion :

[PLSLQ] collections record et tableau


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juin 2004
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 29
    Par défaut [PLSLQ] collections record et tableau
    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
     
    CREATE OR REPLACE PACKAGE Mon_Package IS
     
      TYPE t_rec_prog IS RECORD (num prog.id%TYPE,
                                                 nom prog.nom%TYPE,
                                                 type prog.type%TYPE);
     
      TYPE tab_t_rec_prog IS TABLE OF T_REC_BUG INDEX BY BINARY_INTEGER;
     
      FUNCTION MesProg (p_i NUMBER,
                                    p_parametre1 NUMBER,
                                    p_parametre1 NUMBER ) RETURN TAB_T_REC_PROG;
     
    END Mon_Package;
    /
     
    CREATE OR REPLACE PACKAGE BODY Mon_Package IS
     
    FUNCTION MesProg (p_i NUMBER,
                                  p_parametre1 NUMBER,
                                  p_parametre1 NUMBER) RETURN TAB_T_REC_PROG IS
     
     CURSOR curs IS SELECT num, nom, type
                              FROM prog 
                              WHERE nom = p_parametre1
                                          AND type = p_parametre2;
     
    t_rec TAB_T_REC_PROG;
    i NUMBER := 1;
     
    BEGIN
      FOR rec IN curs LOOP
        t_rec(i).num := curs.num;
        t_rec(i).nom := curs.nom;
        t_rec(i).type := curs.type;
        i := i+1;
      END LOOP;
     
      RETURN(t_rec(p_i));
     
    END Mon_Package;
    /

    Vous voyez l'erreur?
    En fait je cree un type tableau qui contient des record et je retourne a lappelant le record qui corespond a lindice passe en parametre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    62/5     PL/SQL: Statement ignored
    62/30    PLS-00225: subprogram or cursor 'CURS' reference is out of scope
    63/5     PL/SQL: Statement ignored
    63/32    PLS-00225: subprogram or cursor 'CURS' reference is out of scope
    64/5     PL/SQL: Statement ignored
    64/32    PLS-00225: subprogram or cursor 'CURS' reference is out of scope
    65/5     PL/SQL: Statement ignored
    65/31    PLS-00225: subprogram or cursor 'CURS' reference is out of scope
    69/3     PL/SQL: Statement ignored
    69/9     PLS-00382: expression is of wrong type
    [/code]

  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
    1. Sauf erreur de ma part tu retournes 1 enregistrement de ton tableau, donc pas de type tab_t_rec_prog mais de type t_rec_prog.

    2. La bonne syntaxe est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
      FOR rec IN curs LOOP 
        t_rec(i).num := rec.num; 
        t_rec(i).nom := rec.nom; 
        t_rec(i).type := rec.type; 
        i := i+1; 
      END LOOP;

  3. #3
    Membre averti
    Inscrit en
    Juin 2004
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 29
    Par défaut
    merci
    vraiment trop bete lerreur decriture du curseur
    merci encore

  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
    Errare humanum est sed persevare diabolicum !

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

Discussions similaires

  1. jsp taille d'une collection, validation html tableau
    Par DonKnacki dans le forum Servlets/JSP
    Réponses: 4
    Dernier message: 04/03/2010, 13h52
  2. Réponses: 1
    Dernier message: 13/05/2009, 17h21
  3. collection généric VS tableau
    Par djoao dans le forum Framework .NET
    Réponses: 5
    Dernier message: 29/04/2008, 11h28
  4. [Collections] Que choisir (tableau ou Map)
    Par thomine dans le forum Collection et Stream
    Réponses: 6
    Dernier message: 22/06/2005, 16h25
  5. [Collections] Transformer un tableau de données en une chaîne
    Par NATHW dans le forum Collection et Stream
    Réponses: 12
    Dernier message: 03/06/2004, 16h44

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