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 :

Problème de déclaration d'un curseur dans un if


Sujet :

PL/SQL Oracle

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    350
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 350
    Points : 130
    Points
    130
    Par défaut Problème de déclaration d'un curseur dans un if
    Bonjour tout le monde ;
    dans une procédure stocké est-ce possible de creer un curseur au sein d'un if comme suit?

    if(CurDetail.typearticle='Reseauvpn')then
    Cursor toto is
    select res.CODE
    from reseauvpn res,lignedecommande ldc
    where ldc.ARTICLE = res.id
    and ldc.NUMCOMMANDE = numeroCommande;
    end if;

    ça me donne l'erreur suivante :
    (S192) Expecting: ( dans la ligne Cursor toto is.

    s'il vous plait s'il y a un moyen de faire curseur dans un if Merci de me l'indiquer, sinon je peut stocker les resultats de mon select dans un tableau de variable?car mon objectif est le suivant:

    récupérer toute les codes renvoyés par cette requête :
    select res.CODE
    from reseauvpn res,lignedecommande ldc
    where ldc.ARTICLE = res.id
    and ldc.NUMCOMMANDE = numeroCommande;

    et faire des insertions dans une table table1(....).par exemple si ma requête me renvoie 5 codes je dois inserer 5 lignes dans la table en question.
    merci de m'indiquer comment puis-je faire.

    Par avance merci.

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Août 2005
    Messages
    316
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 316
    Points : 388
    Points
    388
    Par défaut
    la declaration du curseur ce fait dans le declare de la procedure

    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
    Cursor toto (z_numcde lignedecommande.NUMCOMMANDE%type) is
                select res.CODE 
                 from reseauvpn res,lignedecommande ldc 
                where ldc.ARTICLE =res.id 
                and ldc.NUMCOMMANDE = z_numcde ;
    begin
          if (CurDetail.typearticle='Reseauvpn') then
            for cde in toto(NUMCOMMANDE )
            loop
                    --mettre les insert ici
            end loop;
          end if;
     
    end;

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    350
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 350
    Points : 130
    Points
    130
    Par défaut
    Merci ça marche bien.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 29/03/2008, 11h36
  2. Réponses: 2
    Dernier message: 06/03/2007, 11h00
  3. Réponses: 8
    Dernier message: 03/11/2006, 15h55
  4. [Vb6] Problème de curseur dans un textbox!
    Par gootsu dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 21/09/2006, 11h31
  5. [MSDE] Problème de curseur dans une SP
    Par papouAlain dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 11/07/2005, 11h28

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