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 :

prob avec une erreur :ORA-04091: table BDPRE.SECTION en mutation


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut prob avec une erreur :ORA-04091: table BDPRE.SECTION en mutation
    Bonjour les amis ,
    merci de m'aider à résoudre ce probléme

    j'ai une table que je veux avant chaque modification :modifier la valeur de la date par sysdate

    le trigger passe sans aucun probléme mais une erreur lors du test m'affiche comme quoi table BDPRE.SECTION en mutation ,déclencheur/fonction ne peut la voir

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    create or replace trigger Insert_DateSection_Update
      before update  on section
      for each row
    begin
      update SECTION
           set DATE_MODIFICATION = SYSDATE 
           where SECTIONID_PK= :old.SECTIONID_PK  ;
        end ;

  2. #2
    Expert confirmé 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
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     :new.DATE_MODIFICATION  := Sysdate;
    à la place de votre update.

  3. #3
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut
    à la place de update ???

    j'ai testé mais çà marche pas

    merci pour la reponse

  4. #4
    Expert confirmé 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
    Par défaut
    Citation Envoyé par SALMHSN Voir le message
    à la place de update ???

    j'ai testé mais çà marche pas

    ...
    Que est-ce que ne marche pas ?
    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
    48
    49
    50
    51
     
    Connected to Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 
    Connected as mni
     
    SQL> 
    SQL> Create table section (
      2    sectionid_pk       number(4) primary key,
      3    text               varchar2(10),
      4    date_modification  date
      5  )
      6  /
     
    Table created
    SQL> create or replace trigger Insert_DateSection_Update
      2    before update  on section
      3    for each row
      4  begin
      5    :new.DATE_MODIFICATION := SYSDATE;
      6  end;
      7  /
     
    Trigger created
    SQL> insert into section values(1, 'TEST', sysdate - 1)
      2  /
     
    1 row inserted
    SQL> Select sectionid_pk, date_modification
      2    From section
      3  /
     
    SECTIONID_PK DATE_MODIFICATION
    ------------ -----------------
               1 13/04/2011 11:47:
    SQL> commit
      2  /
     
    Commit complete
    SQL> update section
      2    set text = 'MODIF'
      3  /
     
    1 row updated
    SQL> Select sectionid_pk, date_modification
      2    From section
      3  /
     
    SECTIONID_PK DATE_MODIFICATION
    ------------ -----------------
               1 14/04/2011 11:47:
     
    SQL>

  5. #5
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut
    Merciiiiiii bcp

    " j'ai pas compris que sans update çà marcherait bien "

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

Discussions similaires

  1. erreur ora-04091:table mutante
    Par lido dans le forum PL/SQL
    Réponses: 7
    Dernier message: 09/02/2009, 12h26
  2. [POO] Prob avec une méthode de classe
    Par Ludo75 dans le forum Langage
    Réponses: 9
    Dernier message: 06/02/2006, 22h37
  3. un noob avec une erreure de noob :(
    Par NoobX dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 09/01/2006, 14h54
  4. Prob avec une image
    Par inferno66667 dans le forum Langage
    Réponses: 2
    Dernier message: 18/11/2005, 11h09
  5. Réponses: 4
    Dernier message: 30/10/2005, 09h13

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