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 :

Construction dynamique de variable


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Inscrit en
    Mars 2009
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 7
    Par défaut Construction dynamique de variable
    Bonjour,

    Mon problème est simple, je souhaite afficher le contenu d'une variable appelée dynamiquement.

    Par exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    MaVariable1 varchar2 := titi;
    MaVariable2 varchar2 := toto;
    Cpt number :=1;
    ChaineRecup varchar2;
     
    ChaineRecup := 'MaVariable'||Cpt; -- je veux récupérer titi et non MaVariable1 
     
    Cpt := Cpt+1;
    ChaineRecup := 'MaVariable'||Cpt; -- je veux récupérer toto et non MaVariable2
    Je ne parviens pas à réaliser cela en PL SQL. Mes recherches n'étant pas fructueuses j'espère avoir une réponse avec ce post. Merci

    Thomas.

  2. #2
    Membre éprouvé
    Avatar de Sunchaser
    Homme Profil pro
    OPNI (Objet Programmant Non Identifié)
    Inscrit en
    Décembre 2004
    Messages
    2 059
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : OPNI (Objet Programmant Non Identifié)
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Décembre 2004
    Messages : 2 059
    Par défaut
    Bonsoir,

    J'imaginerais utiliser un tableau (mais je ne suis pas sur de la finalité, donc juste pour illustrer); qqchose comme:
    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
     
     
    DECLARE
         TYPE my_vars IS TABLE OF VARCHAR2 ( 10 CHAR );
     
         temp_vars   my_vars;
         idx_var     INTEGER;
    BEGIN
         --
         temp_vars                      := my_vars ( );
         temp_vars.EXTEND ( );
         temp_vars ( temp_vars.LAST )   := 'toto';
         temp_vars.EXTEND ( );
         temp_vars ( temp_vars.LAST )   := 'titi';
         --
         idx_var                        := 1;
         DBMS_OUTPUT.put_line ( 'Valeur ' || idx_var || ': ' || temp_vars ( idx_var ) );
         idx_var                        := 2;
         DBMS_OUTPUT.put_line ( 'Valeur ' || idx_var || ': ' || temp_vars ( idx_var ) );
    END;
    Ou bien facon "associative array":
    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 my_vars IS TABLE OF VARCHAR2 ( 10 CHAR )
                              INDEX BY VARCHAR2 ( 10 CHAR );
     
         temp_vars   my_vars;
         idx_var     INTEGER;
    BEGIN
         idx_var                                := 1;
         temp_vars ( 'parameter' || idx_var )   := 'toto';
         idx_var                                := 2;
         temp_vars ( 'parameter' || idx_var )   := 'titi';
         --
         idx_var                                := 1;
         DBMS_OUTPUT.put_line ( 'Valeur param ' || idx_var || ': ' || temp_vars ( 'parameter' || idx_var ) );
         idx_var                                := 2;
         DBMS_OUTPUT.put_line ( 'Valeur param ' || idx_var || ': ' || temp_vars ( 'parameter' || idx_var ) );
    END;
    En espérant t'aider,
    @+

  3. #3
    Membre habitué
    Inscrit en
    Mars 2009
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 7
    Par défaut
    Merci pour ta réponse Sunchaser.

    J'avais pensé à ta solution et je l'ai utilisé, donc je rempli chaque élément de mon tableau à la main; opération dont je me passerais bien en accédant à mes variables de façon dynamique mais le PL ne le permet apparemment pas.

    Bonne fin de journée,
    Thomas

  4. #4
    Membre Expert
    Inscrit en
    Août 2009
    Messages
    1 073
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 1 073
    Par défaut
    Citation Envoyé par Tombzh56 Voir le message
    Bonjour,

    Mon problème est simple, je souhaite afficher le contenu d'une variable appelée dynamiquement.

    Par exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    MaVariable1 varchar2 := titi;
    MaVariable2 varchar2 := toto;
    Cpt number :=1;
    ChaineRecup varchar2;
     
    ChaineRecup := 'MaVariable'||Cpt; -- je veux récupérer titi et non MaVariable1 
     
    Cpt := Cpt+1;
    ChaineRecup := 'MaVariable'||Cpt; -- je veux récupérer toto et non MaVariable2
    Je ne parviens pas à réaliser cela en PL SQL. Mes recherches n'étant pas fructueuses j'espère avoir une réponse avec ce post. Merci

    Thomas.
    Tu peux utiliser un TABLE OF (ie, un array) :

    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
     
    DECLARE
      TYPE myArray IS TABLE OF VARCHAR(50);
      maVariable myArray := myArray(); 
      Cpt number :=1;
      ChaineRecup varchar2(100);
    BEGIN
      maVariable.EXTEND;
      maVariable(1) := 'Aaa';
      maVariable.EXTEND;
      maVariable(2) := 'Bbb';
      -- Variante : déclarer directement maVariable := myArray('Aaa','Bbb')
      ChaineRecup := maVariable(1);
      DBMS_OUTPUT.put_line(ChaineRecup);
      ChaineRecup := maVariable(2);
      DBMS_OUTPUT.put_line(ChaineRecup);
    END;

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

Discussions similaires

  1. [MySQL] Construction dynamique d'un "list treeview"
    Par kilanepa dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 03/03/2006, 17h09
  2. [Language]Nom dynamique de Variable
    Par brooks dans le forum Langage
    Réponses: 13
    Dernier message: 14/12/2005, 18h09
  3. Construction dynamique
    Par rvzip64 dans le forum Langage
    Réponses: 9
    Dernier message: 23/10/2005, 11h23
  4. [Thread] Construction dynamique
    Par Rayek dans le forum Composants VCL
    Réponses: 3
    Dernier message: 21/09/2005, 09h06
  5. [JTree] Construction dynamique
    Par raj dans le forum Composants
    Réponses: 7
    Dernier message: 09/12/2004, 17h03

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