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

Langage SQL Discussion :

Declencheur - trigger


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 4
    Points : 2
    Points
    2
    Par défaut Declencheur - trigger
    Bonjour à tous, je suis nouvelle sur le forum, je m'appel Stéphanie, je suis en L3 maths info, et je viens chercher de l'aide auprès de vous !

    j'ai une table reservation :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TABLE Reservation (
     
    Numres Number (5) not null,
    Numclient Number(5) not null CONSTRAINT ref2_numclient_client REFERENCES client,
    Numchambre Number(3) not null,
    NumHotel number(3) NOT NULL,
    Nbpersaccomp number(5) not null,
    DateArrivee DATE not null,
    DateDepart DATE not null , 
    NbChambre Number(5) not null Constraint dom_Nbchambre check (nbchambre >0 ), 
    dateres DATE not null,
    CONSTRAINT FK_reservation foreign key (numchambre,numhotel) REFERENCES chambre,
    constraint pk_reservation primary key ( numres) 
    );
    je voudrais faire un trigger tel que lors de l'insertion d'une réservation la date d'arrivée soit inférieure à la date de départ.

    j'ai écris cela :

    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
    create or replace trigger contrainte15
    after insert or update on reservation
    for each row
    declare N integer;
    begin 
              select 1 into N
              from reservation
              where datedepart < datearrivee;
     
    raise_application_error ( -20001,'datedepart < date arrivée');
    EXCEPTION
    when no_data_found then null;
    when too_many_rows then raise_application_error ( -20002 ,'trop de ligne c15 violée');
     
    end ;
    /
    Message d"erreur :

    ORA-04091: la table SYSTEM.RESERVATION est en mutation ; le déclencheur ou la fonction ne peut la voirORA-06512: à "SYSTEM.CONTRAINTE15", ligne 3ORA-04088: erreur lors d'exécution du déclencheur 'SYSTEM.CONTRAINTE15'
    Je n'arrive pas à trouver mon erreur, pourriez vous m'aider ?

    Merci d'avance pour votre aide !

  2. #2
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    pourquoi utiliser un trigger pour gerer la contrainte ??

  3. #3
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    je ne vois pas comment faire autrement ! c'est ma prof qui voulait que je fasse comme ca!

  4. #4
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    vous auriez pu poser directement la contrainte sur votre table (cf CHECK)

    Pour le trigger, vous devez faire le test que sur le tuple inséré ou modifié (utilisez :new.colonne si ma memoire est bonne)

    Bon courage

  5. #5
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    merci mais tjs le même message mettant new.datedepart :new.datearrivee ; je me demande s'il n'y a pas un problème à la creation de la table. J'ai toujours le probleme de la table en mutation.

  6. #6
    Membre actif
    Homme Profil pro
    Analyst
    Inscrit en
    Juillet 2008
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Analyst
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2008
    Messages : 150
    Points : 217
    Points
    217
    Par défaut
    Bonsoir,
    Tout d'abord, d'accord avec Yanika_bzh: un check est plus adapté.
    Raison de l'erreur:
    A priori (livre sur oracle), pour des triggers FOR EACH ROW, il n'est pas possible de manipuler la table sur laquelle il y'a le corps du declancheur. Il ne faut donc écrire de façon à ne pas utiliser de FOR EAH ROW

    Solution dans ton contexte(hors CHECK):
    Déjà je mettrai avant insert.
    Ensuite, utilisé simplement les variables soumises par Yanika_bzh

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    create or replace trigger contrainte15
    before insert or update on reservation
    for each row
    begin
     
    if :NEW.datedepart < :NEW.datearrivee then
    raise_application_error ( -20001,'datedepart < date arrivée');
    end if;
     
    end;
    La forme est peut etre pas la meilleure (ça fait longtemps que j'ai pas fait de PL/SQL).

  7. #7
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    ca marche ! merci beaucoup pour votre aide !

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

Discussions similaires

  1. sql trigger declencheur update
    Par fahdijbeli dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 05/07/2012, 19h01
  2. triggers declencheurs verification
    Par mouadmagan dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 09/06/2010, 13h04
  3. [Declencheur] Update dans trigger Insert
    Par gilder89 dans le forum Développement
    Réponses: 2
    Dernier message: 25/05/2007, 10h30
  4. TRIGGER - mise a jour champ de la table declencheur
    Par jane_ng dans le forum Oracle
    Réponses: 1
    Dernier message: 17/06/2006, 19h12

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