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

Oracle Discussion :

Gestion des excceptions


Sujet :

Oracle

  1. #61
    Nouveau membre du Club
    Inscrit en
    Août 2004
    Messages
    92
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 92
    Points : 30
    Points
    30
    Par défaut
    Voici un petit récapitulatif de ce qu'il faut retenir :

    Le FORALL est utilisable uniquement à partir de la version 9.0.2

    L'initialisation du tableau
    VP_Tabl VP_TabType := VP_TabType(null)
    est inutile car le tableau est déclaré avec INDEX BY BINARY_INTEGER

    L'ajout d'une ligne dans le tableau est inutile ( du moins géré automatiquement)
    car le tableau est déclaré avec INDEX BY BINARY_INTEGER
    donc VP_TABL.extend ---> inutile


    Voici les différentes parties du programme (qui fonctionne enfin):

    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
    33
    34
    35
    -- Déclaration 
    TYPE VP_TabType IS TABLE OF T_ANOMAL%ROWTYPE INDEX BY BINARY_INTEGER;
    VP_idx      NUMBER :=0 ;
    VP_Tabl     VP_TabType;
     
     
    -- Procedure d'insertion des données dans le tableau
    PROCEDURE P_ALIM_TABLEAU_ANO (   in_PAT       	IN T_ANOMAL.R_CODPAT%TYPE,
    				 in_FICH     	IN T_ANOMAL.R_fichier%TYPE,
    				 in_CHAMP     	IN T_ANOMAL.r_champs%TYPE,
    				 in_CODEREJ   	IN T_ANOMAL.r_code_rejet%TYPE,
    				 in_R_NATURE_REJET IN T_ANOMAL.r_nature_rejet%TYPE,
    				 in_R_DATE    	IN T_ANOMAL.r_date_rejet%TYPE)
    IS
    BEGIN
        VP_idx := VP_idx + 1 ; -- on incrémente l'INDEX des item
     
         VP_Tabl(VP_idx).R_CODPAT:= in_PAT ;
         VP_Tabl(VP_idx).R_FICHIER:= in_FICH ;
         VP_Tabl(VP_idx).R_CHAMPS:= in_CHAMP;
         VP_Tabl(VP_idx).R_CODE_REJET:= in_CODEREJ;
         VP_Tabl(VP_idx).R_NATURE_REJET:= in_R_NATURE_REJET;
         VP_Tabl(VP_idx).R_DATE_REJET:=SYSDATE;
    END;
     
     
    -- L'appel à la procédure du chargement du tableau
    Pkg_CONT.P_ALIM_TABLEAU_ANO ( in_NO_PAT,   in_FICH, in_CHAMP, '00001',  'La valeur n''existe pas dans la liste proposée',SYSDATE);
     
    -- Récuperation des données du tableau pour insertion dans la table des anomalies.
    FOR i IN VP_Tabl.first..VP_Tabl.last LOOP
    	INSERT INTO T_ANOMAL (R_CODPAT, R_FICHIER, R_CHAMPS, R_CODE_REJET, R_NATURE_REJET, R_DATE_REJET)
    	VALUES(VP_Tabl(i).R_CODPAT,VP_Tabl(i).R_FICHIER, VP_Tabl(i).R_CHAMPS, VP_tabl(i).R_CODE_REJET, VP_Tabl(i).R_NATURE_REJET, VP_Tabl(i).R_DATE_REJET);
    	COMMIT;
    END LOOP;

    Enfin je remercie tout ceux qui ont participé à cet heureux dénouement...

  2. #62
    Membre éprouvé Avatar de Yorglaa
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    845
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2004
    Messages : 845
    Points : 931
    Points
    931
    Par défaut
    heureux que ça fonctionne !!

    et bravo !

  3. #63
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    1 024
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 1 024
    Points : 1 294
    Points
    1 294
    Par défaut
    bien bien....

    Juste un dernier petit truc, moi je mettrais le COMMIT aprés la boucle "for" et non pas dedans...

  4. #64
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Citation Envoyé par delphine_lep
    Le FORALL est utilisable uniquement à partir de la version 9.0.2
    Non, le forall fonctionne depuis la 8i, c'est la syntaxe suivante qui ne fonctionne qu'à partir de la 9.02 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    forall i in monTableau.first..monTableau.last
          insert into maTable value monTableau (i);
    où la variable monTableau est un tableau de type maTable%rowtype.

+ Répondre à la discussion
Cette discussion est résolue.
Page 4 sur 4 PremièrePremière 1234

Discussions similaires

  1. gestion des groupes
    Par muaddib dans le forum QuickReport
    Réponses: 3
    Dernier message: 31/12/2002, 11h01
  2. [reseaux] Gestion des threads en perl
    Par totox17 dans le forum Programmation et administration système
    Réponses: 2
    Dernier message: 28/11/2002, 09h40
  3. Gestion des variables - mémoire ?
    Par RIVOLLET dans le forum Langage
    Réponses: 4
    Dernier message: 26/10/2002, 12h44
  4. Réponses: 4
    Dernier message: 04/07/2002, 12h31
  5. c: gestion des exceptions
    Par vince_lille dans le forum C
    Réponses: 7
    Dernier message: 05/06/2002, 14h11

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