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 :

Traiter ligne par ligne le résultat d'une requête


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2012
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Mars 2012
    Messages : 35
    Par défaut Traiter ligne par ligne le résultat d'une requête
    Bonjour ,
    voici mon problème
    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 FUNCTION controle(cd_collab number) retrun nbe_jours is
    
    cursor cur_collab is 
    
    SELECT a.cd_collab,cd_absence,dat_deb,dat_fin
                                          INTO collab,datd,datf
                                          from absence a,demande_absence d
                                          where d.CD_DEM_ABS=a.CD_DEM_ABS
                                          and d.CD_ETAT= 4
                                          and a.CD_MOTIF in (2,3)
                                          and d.DAT_DEMANDE >='01/02/2012'
                                          order by d.cd_collab,cd_absence asc
                                
    
    var_collab  cur_collab%rowTYPE;
    var_absence cur_collab%rowTYPE;                                    
    
                                      
    BEGIN
    
    loop 
    // ici je veux selectionner la date de fin la plus grande de chaque collaborateur (exp pour le cd_collab 175 prendre la date 03/07/2012 
    
    select max(dat_fin) from cur_collab where cd_collab= var collab ;
             if max(dat_fin) = dat_deb -1 then 
    nbr_jours := dat_fin - dat_deb;
    else
    nbr_jours := dat_fin -dat_deb;
    end if ;
    
    
    return nbr_jours

  2. #2
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    C'est quoi le problème si ce n'est une syntaxe cousue de fautes et non finie ?

  3. #3
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2012
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Mars 2012
    Messages : 35
    Par défaut
    oui tout a fait , et j'ai envie de savoir est ce que j'ai le droit de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select Max (dat_fin) from cur_collab where cd_collab = var_collab;
    from cur_collab , c'est toléré ?

    merci

  4. #4
    Membre Expert Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 38
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Par défaut
    Il serait peut-être utile de revoir le fonctionnement des curseurs

    Déclaration du curseur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    CURSOR C_zen IS
       SELECT a
       FROM MaTable
    Appel du curseur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    OPEN C_zen;
    FETCH C_zen INTO MaVar;
     -- mes traitements
    CLOSE C_zen

  5. #5
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    oui tout a fait , et j'ai envie de savoir est ce que j'ai le droit de faire :
    Select Max (dat_fin) from cur_collab where cd_collab = var_collab;
    Tu peux mais dans ce cas il faut récupérer le résultat (et non les, un SELECT ne supporte que le renvoie d'une seule ligne de données) comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT	Champs1, Champs2
    INTO	Var1, Var2
    FROM	ma_table
    WHERE	ChampsX = ma_condition;

  6. #6
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2012
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Mars 2012
    Messages : 35
    Par défaut
    ok merci et si dans ma condition je veux récupérer le cd_collab sélectionné en ce moment avec mon curseur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Select Max (dat_fin) into var_date from absence where cd_collab = X.
    X= cd_collab sélectionné actuellement par le cursor

Discussions similaires

  1. Réponses: 8
    Dernier message: 04/07/2011, 15h16
  2. Affichage par "section" des résultats d'une requête
    Par tiboleo dans le forum ASP.NET
    Réponses: 4
    Dernier message: 03/02/2010, 17h43
  3. Calcul ligne par ligne sur le résultat d'une requête
    Par CanardJM dans le forum Langage SQL
    Réponses: 5
    Dernier message: 15/04/2008, 14h06
  4. Charger une texture ligne par ligne
    Par YéTeeh dans le forum OpenGL
    Réponses: 6
    Dernier message: 09/05/2006, 10h58
  5. aditionner les champs d'une table ligne par ligne
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 3
    Dernier message: 09/08/2005, 09h38

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