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

Administration Oracle Discussion :

Trigger suite à un insert.


Sujet :

Administration Oracle

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 4
    Points : 2
    Points
    2
    Par défaut Trigger suite à un insert.
    Bonjour,
    Je voudrais de l'aide pour quelque chose de fort simple je suppose.
    Je débute sous Oracle, et j'ai bien du mal à créer un simple trigger.

    Je voudrais que mon trigger, lors de l'insertion d'une ligne dans la table Commande, permette la mise à jour de l'attribut commandeEnCours (=0 si pas de commande en cours, =1 si commande en cours)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    table Client(idClient, nomClient, CommadeEnCours);
    table Commande(idCommande, montant, idClient)
    Merci beaucoup de votre aide
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE OR REPLACE TRIGGER  EtatCommande after insert on Commande
    BEGIN
      UPDATE Exemplaire SET CommandeEnCours=1 where idClient=?????
    END  EtatCommande;
    J'ai essayé de remplace les ??? par un new, mais ça ne fonctionne pas.
    ORA-04082: références NEW ou OLD interdites dans déclencheurs niveau table. Je suis sur que c'est simple, mais je débute et je n'y arrive pas. Merci

  2. #2
    Rédactrice

    Avatar de kalyparker
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Janvier 2007
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 327
    Points : 2 998
    Points
    2 998
    Par défaut
    Bonjour et bienvenue sur le forum,

    avec un :new ça devrais passer

    PS : tu devrais utiliser les balises [code]

    Sinon va faire un tour sur le site tu devrais trouver quelques infos.

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    J'ai toujours l'alerte : ORA-04082: références NEW ou OLD interdites dans déclencheurs niveau table

    Et j'ai parcouru le site (trop rapidement ??) et je n'ai pas trouvé mon bonheur

  4. #4
    Rédacteur

    Homme Profil pro
    Développeur et DBA Oracle
    Inscrit en
    Octobre 2006
    Messages
    878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur et DBA Oracle

    Informations forums :
    Inscription : Octobre 2006
    Messages : 878
    Points : 1 197
    Points
    1 197
    Par défaut
    Bonjour,

    Tu rajoutes dans ton déclencheurs et tu peux utiliser :new....

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    En effet, ça marche. Mais pour for Each Row, cela ne risque t'il pas d'avoir des conséquences sur le temps d'exécution si la table commande contient beaucoup de lignes. Il n'y a qu'une ligne que j'affecte à la fois.
    Merci.

  6. #6
    Rédactrice

    Avatar de kalyparker
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Janvier 2007
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 327
    Points : 2 998
    Points
    2 998
    Par défaut
    salim11, tu as été plus rapide que moi sur ce coup là !

    Il n'y a qu'une ligne que j'affecte à la fois.
    C'est le principe du trigger !

    Si tu veux faire autrement, tu peux lors de l'appel mettre directement la valeur de CommandeEnCours à 1.
    Après ça dépend de ce que tu veux...

    N'oublie pas de mettre le sujet à résolu

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    C'était un exemple simpliste, ici.
    Parce qu'en fait le trigger est là pour assurer de nombreuses contraintes diverses. Dans une base plus complexe. Je suis étudiant et je débute sous Oracle, bien que j'ai une petite expérience du SQL

  8. #8
    Rédactrice

    Avatar de kalyparker
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Janvier 2007
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 327
    Points : 2 998
    Points
    2 998
    Par défaut
    Un peu d'aide ...
    si tu parles un peu la langue de shakespeare ici tu trouveras les 3 sortes de triggers utiliser en oracle :

    http://www.adp-gmbh.ch/ora/sql/create_trigger.html

    sinon google est ton ami

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

Discussions similaires

  1. [VBA-E] Incrémentation automatique d'une valeur suite à l'insertion de ligne
    Par abdelghani_k dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 31/01/2007, 14h26
  2. Réponses: 4
    Dernier message: 30/06/2006, 21h48
  3. Simple Trigger before on insert.
    Par gregb34 dans le forum Oracle
    Réponses: 7
    Dernier message: 28/05/2006, 07h27
  4. Réponses: 2
    Dernier message: 01/03/2006, 15h16
  5. trigger suite a insert
    Par DaxTaz dans le forum Développement
    Réponses: 4
    Dernier message: 07/07/2004, 11h27

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