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 :

Fonction recursive plante session


Sujet :

PL/SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 92
    Points : 57
    Points
    57
    Par défaut Fonction recursive plante session
    Bonjour

    j'ai une table HD_MAT comme suit

    CDMAT CDMATR
    1 10
    2 10
    3 10
    4 10
    10 20
    11 20
    12 20
    13 20

    J'ai la fonction recusive suivante
    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
    CREATE OR REPLACE FUNCTION TEST(p_cdmatr IN VARCHAR2) return number IS
        TYPE TABLE_CDMAT IS TABLE OF VARCHAR2(20) INDEX BY BINARY_INTEGER;
        var_tab_cdmat TABLE_CDMAT;
        retour number;
      BEGIN
        SELECT CDMAT
        BULK COLLECT 
        INTO var_tab_cdmat
        FROM HD_MAT
        WHERE CDMATR=p_cdmatr;
     
        IF var_tab_cdmat.COUNT>0 THEN
          FOR iCnt IN var_tab_cdmat.FIRST..var_tab_cdmat.LAST LOOP
            dbms_output.put_line('LIGNE '||var_tab_cdmat(iCnt));
            retour :=TEST(var_tab_cdmat(iCnt));
          END LOOP;
        END IF;
        return 1;
      END;
    /
    je l'appel comme suit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    declare
    retour number;
    begin
    retour:=test('20');
    dbms_output.put_line('FIN');
    end;
    /
    normalement il devrait m'afficher

    10
    1
    2
    3
    4
    11
    12
    13

    mais il affiche
    10
    10
    10
    10
    10
    10
    10
    10
    10
    ...
    ...

    à l'infini

    quelqu'un peut m'aider

    cordialement

  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
    Chez moi ça marche avec du type number (champs de la table HD_MAT)

  3. #3
    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
    J'ai réessayé en créant avec des varchar2 et avec le même code de fonction, résultat correct.

    T'es sur que t'as pas une ligne '10', '10' ,

  4. #4
    Expert éminent sénior 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
    Points : 11 252
    Points
    11 252
    Par défaut
    Bref, l’exemple telle qui est fourni fonctionne. Mais en ce qui concerne l’algorithme …
    De plus il suffit d’ajouter le touple 10 20 dans le données et bonjour les dégâts.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 92
    Points : 57
    Points
    57
    Par défaut
    Désolé

    c'était bien une ligne '10' '10'
    qui posait probleme
    et faisait boucler à l'infini

    en rajoutant un test entre ce qui est passé à la fonction
    et ce qui est récupéré dans le bulk pour appelé la fonction
    seulement s'ils sont différents il n'y a plus de soucis

    Merci

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 22/12/2005, 11h20
  2. [XSL]Probleme fonction recursive
    Par Le-Cortex dans le forum XSL/XSLT/XPATH
    Réponses: 9
    Dernier message: 12/12/2005, 15h10
  3. probleme sql, fonction recursive
    Par CaptainChoc dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/11/2005, 01h45
  4. La fonction DestroyWindow plante !!!
    Par Jean++ dans le forum MFC
    Réponses: 3
    Dernier message: 26/08/2005, 10h32
  5. [PL/SQL] fonction et alter session
    Par aline dans le forum Oracle
    Réponses: 10
    Dernier message: 26/01/2005, 15h23

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