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 :

Différentes requetes possibles dans une boucle


Sujet :

PL/SQL Oracle

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Points : 159
    Points
    159
    Par défaut Différentes requetes possibles dans une boucle
    Bonjour,

    J'ai plusieurs cas possibles qui entraînent plusieurs requêtes possibles pour les données à parcourir dans une boucle.

    Y a-t-il un moyen de déclarer une requête
    du genre m_requete VARCHAR2(500);
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    if (....) then
    requete := 'select ...............................';
    elsif () then
    requete := 'select ...............................';
    ...
    else
    requete := 'select ...............................';
    end if;
     
    for c_data in (m_requete)
    loop
    end loop;

  2. #2
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Oui, mais avec un OPEN cursor FOR v_requete

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Points : 159
    Points
    159
    Par défaut
    OK; tu peux m'expliquer comment ça s'utilise?

    Je vois partout que des :
    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
    Declare
      2     -- Déclaration du curseur
      3     CURSOR C_EMP IS
      4     Select
      5        *
      6     From
      7        EMP
      8     Where
      9        job = 'CLERK'
     10     ;
     11  
     12  Begin
     13     For Cur IN C_EMP Loop
     14       dbms_output.put_line( To_char( Cur.empno ) || ' - ' || Cur.ename ) ;
     15     End loop ;
     16  End ;
    Je comprend pas comment déclarer le curseur, comment écrire la boucle
    OPEN cursor FOR v_requete
    loop
    n'a pas l'air de fonctionner
    et comment accéder aux données.

    j'ai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    IS
    v_requete VARCHAR2(500);
    BEGIN
    ...
    if(...)then
    v_requete := ...;
    else
    v_requete := ...;
    end if;
     
    OPEN cursor FOR v_requete 
    loop
    --syntaxe incorrecte + comment accéder aux champs?
    end loop;

  4. #4
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Regarde cette discussion. Le premier post est correct (sauf l'alter table)
    http://www.developpez.net/forums/d91...e/#post5189601

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Points : 159
    Points
    159
    Par défaut
    Heureusement que j'ai fini par arriver sur ça :
    http://download.oracle.com/docs/cd/B...0/adg09dyn.htm

    parce que je m'en sortais pas!

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

Discussions similaires

  1. Condition if "différent de 0" dans une boucle for
    Par PIERAN dans le forum MATLAB
    Réponses: 2
    Dernier message: 04/12/2014, 21h01
  2. [PHP 5.3] Requete Delete dans une boucle
    Par Invité dans le forum Langage
    Réponses: 1
    Dernier message: 01/03/2013, 16h22
  3. [MySQL] récupérer dans une boucle chaque information MySQL dans une variable différente
    Par gtenthorey dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/05/2007, 22h34
  4. [MySQL] Requetes SQL dans une boucle PHP
    Par Siteac dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 12/11/2006, 14h35
  5. Réponses: 3
    Dernier message: 06/07/2004, 10h21

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