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

SQL Oracle Discussion :

erreur lors de la compilation d'un trigger


Sujet :

SQL Oracle

  1. #1
    Membre confirmé Avatar de scofild20
    Inscrit en
    Mars 2007
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 109
    Par défaut erreur lors de la compilation d'un trigger
    bonjour je voulais faire un trigger pour mettre a jours ma table payement_etudiant , mais je recoit une erreur de compilation . voici le code

    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
    create or replace trigger liste_nn_pay
      after insert or update or delete on payement_etudiant for each row
    declare 
     var number ;
     var2 number;
    begin
       if inserting or updating Then  
     
    select count(id_etudiant) into var from payement_etudiant where payement_etudiant.id_etudiant=:new.id_etudiant and payement_etudiant.mois = 'septembre';
     
    	if var >0 then 
    		delete from v_champ where id_etudiant=:new.id_etudiant;
    	end if ;
     
    elsif deleting then 
    select count(id_etudiant) into var2 from payement_etudiant where payement_etudiant.id_etudiant=:old.id_etudiant and payement_etudiant.mois = 'septembre';
     
    		if var2 =0 then 
                           insert into v_champ values(:old.id_etudiant) where id_etudiant=:old.id_etudiant;
    		end if;
     
       End if ;
    End;
    /
    le compilateur me signale une erreur dans cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    elsif deleting then 
    select count(id_etudiant) into var2 from payement_etudiant where payement_etudiant.id_etudiant=:old.id_etudiant and payement_etudiant.mois = 'septembre';
    en affirmant la commande sql ne se termine pas correctement.

    quelqu'un peut m'aider ?

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

    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
    Billets dans le blog
    4
    Par défaut
    Les erreurs de compilations, normalement on ne les corrige pas sur le forum.
    Mais comme ce problème t'en posera un autre :


    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
    36
    CREATE OR REPLACE TRIGGER liste_nn_pay
      after INSERT OR UPDATE OR DELETE ON payement_etudiant FOR each row
    declare 
     var number ;
    begin
     
    IF inserting OR updating
    Then  
     
    	SELECT count(*) INTO var 
    	FROM payement_etudiant 
    	WHERE id_etudiant=:new.id_etudiant 
    	AND mois = 'septembre';
     
    	IF var >0 
    	then 
    		DELETE FROM v_champ
    		WHERE id_etudiant=:new.id_etudiant;
    	end IF ;
     
    elsif deleting 
    then 
    	SELECT count(*) INTO var 
    	FROM payement_etudiant 
    	WHERE id_etudiant=:old.id_etudiant 
    	AND mois = 'septembre';
     
    	IF var =0
    	then 
                INSERT INTO v_champ VALUES(:old.id_etudiant) 
    	    WHERE id_etudiant=:old.id_etudiant;
    	end IF;
    End IF ;
     
    End;
    /
    Y'a déjà un problème au niveau de l'insert . .une clause where avec un values ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     INSERT INTO v_champ VALUES(:old.id_etudiant) 
    WHERE id_etudiant=:old.id_etudiant;
    Sinon, le problème que tu ne pourras pas gérer : Tu ne peux pas lire une table dans les triggers For Each Row sur cette table.
    Tu auras l'erreur MUTATING TABLE.

  3. #3
    Membre confirmé Avatar de scofild20
    Inscrit en
    Mars 2007
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 109
    Par défaut
    merci pour votre réponse , je vais essayer de resoudre le problème autrement

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 09/04/2015, 11h01
  2. Erreur lors de la compilation de MySQL
    Par webrider dans le forum SUSE
    Réponses: 2
    Dernier message: 06/03/2007, 11h21
  3. Erreur lors de la compilation avec OmniORB
    Par JohnKwada dans le forum CORBA
    Réponses: 1
    Dernier message: 07/09/2006, 17h34
  4. erreur lors de la compilation
    Par ksoft dans le forum MFC
    Réponses: 2
    Dernier message: 02/05/2006, 15h40
  5. Réponses: 4
    Dernier message: 22/02/2006, 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