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 :

Curseur paramétré & listes


Sujet :

PL/SQL Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2010
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 5
    Par défaut Curseur paramétré & listes
    Bonjour,

    Je souhaiterai pouvoir passer en paramètre à un curseur les éléments d'une liste : "... where col in ( ...param.... ) ".
    Je ne trouve pas la bonne syntaxe. Est-ce que quelqu'un peut m'aider ?

    Je voudrais faire un curseur du style :

    Declare
    Cursor mon_curseur ( liste varchar2 ) Is
    Select .... From ... Where nom in ( liste );
    ;
    ma_liste varchar2(1000);

    Begin

    -- ma_liste sera constituée dynamiquement dans le code PL/SQL à partir d'autre informations
    ma_liste := '''nom1'',''nom2''' :

    for mc in mon_curseur (ma_liste)
    loop
    ....
    en loop;
    End ;

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2010
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 5
    Par défaut
    Super ! ça fonctionne...

    Merci

    ça donne à peu près ça :
    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
    create or replace type mon_type  as table of varchar2(10);
    /
     
    begin
      declare
        cursor mon_curseur (tb mon_type) is
          select .... from ....
            where ... in (select * from TABLE( tb ));
     
        mon_tableau mon_type;
        ma_chaine varchar2(100);
        pos number(3);
     
        begin
     
          ma_chaine := 'abc-def-ghi-jkl-';
          mon_tableau := mon_type(' ');
     
          loop
            pos := instr( ma_chaine, '-' );
            exit when (nvl(pos,0) = 0);
            mon_tableau.extend;
            mon_tableau(mon_tableau.count) := ltrim(rtrim(substr(mon_tableau,1,pos-1)));
            acc1 := substr( ma_chaine, pos+1 );
          end loop;
        ...
        for c_uf_p in moncurseur (mon_tableau)
        loop
          ...
        end loop;
        ...
    end;

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

Discussions similaires

  1. Requête paramétrée avec liste déroulante
    Par rimrim dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 19/12/2006, 09h05
  2. Curseurs paramétrés en T-SQL ??
    Par evans dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 06/04/2006, 15h35
  3. [Forms 6i] Positionnement du curseur dans une liste
    Par Veve44 dans le forum Oracle
    Réponses: 2
    Dernier message: 13/12/2005, 16h28
  4. déclaration de curseur paramétré
    Par new_wave dans le forum Oracle
    Réponses: 3
    Dernier message: 21/11/2005, 14h53
  5. Curseurs paramétrables
    Par KNITTEL dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 08/06/2005, 14h52

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