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 :

Trigger sql défaillant


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    78
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 78
    Points : 37
    Points
    37
    Par défaut Trigger sql défaillant
    Bonjour, tout d'abord je vous montre mon 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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
     
    CREATE OR REPLACE TRIGGER ANOMALIES
    AFTER INSERT ON CAPACITE FOR EACH ROW
    declare 
    	SimpleVar integer;
    	DoubleVar integer;
    	idResVar integer;
    	idCentreVar integer;
    	idClientVar integer;
    	NumSemaineVar integer;
    	AnneeVar integer;
    	NbrChSimpleVar integer;
    	NbrChDoubleVar integer;
    	DureeVar integer;
     
    	CURSOR c1 IS SELECT IdReservation,IdCentre.IdCentre,IdClient.IdClient,NumSemaine.NumSemaine,Annee.Anee,NbrChSimple,NbrChDouble,DureeSejour 
    			      FROM RESERVATION
    			      WHERE IdCentre.IdCentre = :NEW.IdCentre
    			      AND Annee.Annee = :NEW.Annee
    			      AND NumSemaine.NumSemaine+DureeSejour > :NEW.NumSemaine
    			      ORDER BY NumSemaine.NumSemaine;
     
     
    BEGIN
    	SimpleVar := :NEW.NbrChSimpleDisponible;
    	DoubleVar := :NEW.NbrChDoubleDisponible;
     
    	OPEN C1;
    		FETCH C1 INTO idResVar,idCentreVar,idClientVar,AnneeVar,NumSemaineVar,NbrChSimpleVar,NbrChDoubleVar,DureeVar;
    		IF((SimpleVar-NbrChDoubleVar >=0) AND (DoubleVar-NbrChDoubleVar >=0))
    		THEN
    			SimpleVar := SimpleVar-NbrChSimpleVar;
    			DoubleVar := DoubleVar-NbrChDoubleVar;
    		END IF;
    		ELSE
    		BEGIN
    		INSERT INTO ANOMALIE Select seq_anomalie.nextval,idResVar,REF(a),REF(b),REF(c),REF(c),NbrChSimpleVar,NbrChDoubleVar,DureeVar
    				     FROM CENTRE a, CLIENT b, SEMAINE c
    				     Where a.IdCentre = idCentreVar
    				     And b.IdClient = idClientVar
    				     And c.Annee = AnneeVar
    				     And c.NumSemaine = NumSemaineVar;
    		DELETE FROM RESERVATION WHERE IdReservation = idResVar;
    		END;
    	CLOSE C1;
    END;
    /
    Le trigger m'affiche une erreur à la compilation qui est celle-ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    ERREUR à la ligne 32 : PLS-00103: Symbole "ELSE" rencontré à la place d'un des symboles suivants :
     
       begin case declare end exception exit for goto if loop mod
       null pragma raise return select update while with
     
        << close current delete fetch lock insert
       open rollback savepoint set sql execute commit forall merge
       pipe
    Je ne sais vraiment pas d'ou vient cette erreur et j'appprécierai l'aide de quelqu'un
    Merci d'avance.

  2. #2
    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
    Réponse dans le tutoriel

  3. #3
    Membre expert
    Avatar de LeoAnderson
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 2 938
    Points : 3 199
    Points
    3 199
    Par défaut
    IL s'agit de débugger votre code.

    Quel est l'intérêt d'un tel "problème" sur un forum ?

Discussions similaires

  1. Trigger SQL - Base SAGE
    Par Silvia12 dans le forum Développement
    Réponses: 9
    Dernier message: 13/12/2007, 09h47
  2. Problème Trigger SQL Server
    Par RodEpsi dans le forum Développement
    Réponses: 6
    Dernier message: 25/05/2006, 15h03
  3. JDBC et le Trigger SQL server
    Par fadex dans le forum JDBC
    Réponses: 2
    Dernier message: 01/05/2006, 23h25
  4. Attaquer une base externe à partir d'un trigger SQL Server
    Par stephpr44 dans le forum Développement
    Réponses: 5
    Dernier message: 29/10/2005, 15h40
  5. [Triggers SQL]
    Par Abdelmoumen dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 06/09/2005, 18h01

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