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 :

générer dynamiquement un curseur


Sujet :

SQL Oracle

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Points : 25
    Points
    25
    Par défaut générer dynamiquement un curseur
    Bonjour,
    Voilà j'avance bien dans le paquetage que je veux faire mais je suis confronté à un soucis. J'aimerai, dans une fonction, parcourir une table à l'aide d'un curseur implicite. Mais j'aimerai surtout pouvoir fournir cette requête en argument à ma fonction et ainsi générer dynamiquement la création de mon curseur.

    le code 'en dur'
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
      	function  Get_columns_from_tmp_table( req varchar2 ) Return tab_rec_columns IS
    	cols Pkg_PrswGen.tab_rec_columns;
    	cpt int:= 1;
    	begin
    		 for tmp_col_line in (select mycode, mytype from SWIFT_PRSW_FIELDS_TMP) loop
    	  	 	 cols(cpt).fieldname := tmp_col_line.mycode;
    		 	 cols(cpt).fieldtype := tmp_col_line.mytype;  
    		 	 cpt:=cpt+1;
    	  	 end loop;
     
    		 return cols;
    	end;
    ce code ne fonctionne pas mais l'idée est là !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
      	function  Get_columns_from_tmp_table( req varchar2 ) Return tab_rec_columns IS
    	cols Pkg_PrswGen.tab_rec_columns;
    	cpt int:= 1;
    	begin
    		 for tmp_col_line in req loop
    	  	 	 cols(cpt).fieldname := tmp_col_line.mycode;
    		 	 cols(cpt).fieldtype := tmp_col_line.mytype;  
    		 	 cpt:=cpt+1;
    	  	 end loop;
     
    		 return cols;
    	end;
    J'ai rechercher sur le forum et je suis tombé sur un post assez vieux recommandant l'article :
    http://sheikyerbouti.developpez.com/dynamic/dynamic.htm

    J'ai aussi regardé cet article
    http://sheikyerbouti.developpez.com/..._immediate/#L1

    mais sans succès ...

    A vot' bon coeur.

    Emilien

  2. #2
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Points : 25
    Points
    25
    Par défaut
    Mauvaise question ?

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    il sort d'où req loop ?

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Points : 25
    Points
    25
    Par défaut
    Citation Envoyé par orafrance Voir le message
    il sort d'où req loop ?
    Le req loop c'était pour donner une idée de ce que j'aimerai faire.
    Plus je test moins j'ai l'impression que c'est possible.

    En fait j'aimerai faire cette action sur plusieurs tables.

    Dans req il y aurait une requete SQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    req:='SELECT mycode, mytype FROM SWIFT_PRSW_FIELDS_TMP';
    ou la clause where changerait.

  5. #5
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    A priori un REF CURSOR devrait suffire:
    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
    DECLARE
      cur sys_refcursor;
      LC$Req  VARCHAR2(1000);
      LC$C1   VARCHAR2(1000);
      LC$C2   VARCHAR2(1000);  
    BEGIN
      LC$Req := 'select empno, ename from emp' ;
      OPEN cur FOR LC$Req ;
      LOOP
        FETCH cur INTO LC$C1, LC$C2 ;
        DBMS_OUTPUT.PUT_LINE( LC$C1 || '-' || LC$C2 ) ;
        EXIT WHEN cur%NOTFOUND ;
      END LOOP;
      CLOSE cur ;
    END;
    Rédacteur Oracle (Oracle ACE)
    Guide Oracle ,Guide PL/SQL, Guide Forms 9i/10g, Index de recherche
    Je ne réponds pas aux questions techniques par MP
    Blogs: Forms-PL/SQL-J2EE - Forms Java Beans

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Points : 25
    Points
    25
    Par défaut Yeah
    Ca marche niquel !!!!
    Merci beaucoup et bon jeudi !!!!


    Emilien

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 11/02/2006, 12h07
  2. [DTS]générer dynamiquement des tables Postgres 8.0
    Par CetTer dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 08/10/2005, 10h35
  3. WINAPI : Changer dynamiquement le curseur
    Par Grficos dans le forum MFC
    Réponses: 3
    Dernier message: 25/08/2005, 19h31
  4. [PL/SQL] SQL Dynamique et curseur
    Par Loko dans le forum Oracle
    Réponses: 10
    Dernier message: 23/11/2004, 16h18
  5. Réponses: 2
    Dernier message: 31/08/2002, 14h00

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