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 :

Probleme Trigger et curseur


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Janvier 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 2
    Par défaut Probleme Trigger et curseur
    Bonjour,

    Je voudrai verifier sur ma base que les prenoms inseré dans ma table etudiant sont bien des prenom de garcons. Pour cela j'ai crée une table prenom contenant un dictionnaire de prenom de garcon. J'ai ensuite crée ce trigger qui se compile bien mais fait finalement l'inverse de ce que je veux:

    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
    Create or replace trigger TRIGG_PRENG
    BEFORE insert or update on ETUDIANTS
    FOR EACH ROW
    declare cursor PREN_CUR is
    select distinct id,prenom from PRENOMS_GARCONS;
    PREN etudiants.prenom%TYPE;
    Id PRENOMS_GARCONS.id%TYPE;
    erreur EXCEPTION;
    begin
    open PREN_CUR;
    loop
    fetch PREN_CUR into Id,PREN;
    exit when PREN_CUR%NOTFOUND;
    IF (:new.civ='Monsieur') or (:new.civ='Mr') AND :new.PRENOM NOT LIKE PREN then
    RAISE erreur;
    end if ;
    end loop;
    close PREN_CUR;
    EXCEPTION
    	WHEN erreur THEN
    		RAISE_application_error(-20002,'Ce n est pas un prenom de garcon');
    end;
    /
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into ETUDIANTS (NUMETUDIANT,CIV,NOM,PRENOM,TELFIXE,TELMOB,DNETUD,ADRNUM,ADRRUE,ADRCP,ADRVILLE) values('E48','Mr','Clement','Clement','0157708080','0653777780','vendredi, octobre 16, 1987','105','Rue de Belleville', '75019','PARIS');
    Cette insertion passe dans l'exception je ne vois pas pourquoi alors que le prenom Clement figure bien dans ma table prenom.

    Merci pour vos reponses

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    354
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 354
    Par défaut
    Citation Envoyé par snkyo Voir le message
    IF (:new.civ='Monsieur') or (:new.civ='Mr') AND :new.PRENOM NOT LIKE PREN
    Je n'ai pas regardé le reste attentivement mais ici il y deux points
    - Pourquoi "not like"? "!=" suffirait normalement
    - l'erreur par contre est la non utilisation de parenthèses!

    Ce qui est écrit sera exécuté ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    IF (:new.civ='Monsieur') or ( (:new.civ='Mr') AND :new.PRENOM NOT LIKE PREN )
    Or je suppose que ce qui est attendu est ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    IF ( (:new.civ='Monsieur') or (:new.civ='Mr') ) AND :new.PRENOM NOT LIKE PREN

  3. #3
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    c'est pas plus simple de faire:
    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 TRIGGER TRIGG_PRENG
    BEFORE INSERT OR UPDATE ON ETUDIANTS
    FOR EACH ROW
    DECLARE
    dummy INTEGER;
    BEGIN
    IF (:new.civ='Monsieur') OR (:new.civ='Mr') THEN
      SELECT 1
         INTO dummy
        FROM DUAL
      WHERE EXISTS (
               SELECT 1 
                 FROM PRENOMS_GARCONS
               WHERE prenom = :new.PRENOM
                           );
    END IF;
    EXCEPTION WHEN NO_DATA_FOUND THEN 
    RAISE_application_error(-20002,'Ce n est pas un prenom de garcon');
    END;
    /

  4. #4
    Nouveau candidat au Club
    Inscrit en
    Janvier 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 2
    Par défaut
    Merci beaucoup cette solution fonctionne parfaitement et est bien moins lourde

    Bonne soirée

  5. #5
    Membre éclairé Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Par défaut
    La solution du grand Maitre OraFrance me convient très bien. Est-ce qu'on ne peut pas l'écrire comme suit :

    CREATE OR REPLACE TRIGGER TRIGG_PRENG
    BEFORE INSERT OR UPDATE ON ETUDIANTS
    FOR EACH ROW
    DECLARE
    dummy INTEGER;
    BEGIN
    IF (:new.civ='Monsieur' OR :new.civ='Mr') THEN
    SELECT 1 INTO dummy
    FROM PRENOMS_GARCONS
    WHERE prenom = :new.PRENOM;
    END IF;
    EXCEPTION WHEN NO_DATA_FOUND THEN
    RAISE_application_error(-20002,'Ce n est pas un prenom de garcon');
    END;
    /
    Merci.
    LBO72.

  6. #6
    Membre éclairé Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Par défaut
    Je pense que ma solution ne fonctionnerait pas s'il y'a plusieurs même PRENOM

    LBO72.

Discussions similaires

  1. Problème trigger BEFORE UPDATE
    Par berceker united dans le forum SQL Procédural
    Réponses: 8
    Dernier message: 30/08/2006, 16h55
  2. probleme trigger
    Par sanyugioh dans le forum Oracle
    Réponses: 3
    Dernier message: 13/04/2006, 15h46
  3. Probleme trigger mysql 5
    Par DarkMax dans le forum SQL Procédural
    Réponses: 7
    Dernier message: 18/03/2006, 22h50
  4. Problem Trigger instead of
    Par bubi dans le forum Développement
    Réponses: 1
    Dernier message: 01/12/2005, 23h31
  5. probleme trigger
    Par samourai_alex dans le forum Oracle
    Réponses: 10
    Dernier message: 05/01/2005, 11h37

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