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 Oracle 9i


Sujet :

PL/SQL Oracle

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

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Probleme Trigger Oracle 9i
    Bonjour,

    Je rencontre un probleme lors de l'execution d'un trigger.

    J'obtiens toujours ce message d'erreur :

    Error starting at line 1 in command:
    INSERT INTO TRANSPLAN.ESSAI_HIST(NOM, CLE) VALUES ('vghj',88888)
    Error report:
    SQL Error: ORA-01722: Nombre non valide
    ORA-06512: à "TRANSPLAN.TRIG_ESSAI", ligne 2
    ORA-04088: erreur lors d'exécution du déclencheur 'TRANSPLAN.TRIG_ESSAI'


    Voici le code du trigger :

    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 TRIG_ESSAI BEFORE INSERT ON ESSAI_HIST 
    FOR EACH ROW 
    BEGIN
    MERGE into TRANSPLAN.ESSAI v
    using ( select :new.CLE CLE from dual ) t1
    on ( t1.CLE = v.CLE)
    when matched
    then update set
    NOM = :new.NOM
    when not matched
    then insert values (
    :new.CLE,
    :new.NOM
    );
    end;
    Et voici les deux tables en questions :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE "TRANSPLAN"."ESSAI" 
       (    "CLE" NUMBER(15,0) NOT NULL ENABLE, 
        "NOM" VARCHAR2(10 BYTE), 
         CONSTRAINT "ESSAI_PK" PRIMARY KEY ("CLE") ENABLE
       ) ;
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE "TRANSPLAN"."ESSAI_HIST" 
       (    "CLE" NUMBER(15,0) NOT NULL ENABLE, 
        "NOM" VARCHAR2(10 BYTE)
       ) ;
    Sur internet j'ai rien trouvé. Je suis un peu désespéré.

    Merci de votre aide.

  2. #2
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Utilise les balise code (icone # lors des messages)

    Essaie en nommant les colonnes d'insert.
    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
    CREATE OR REPLACE
    TRIGGER TRIG_ESSAI BEFORE INSERT ON ESSAI_HIST 
    FOR EACH ROW 
    BEGIN
    MERGE into TRANSPLAN.ESSAI v
    using ( select :new.CLE CLE from dual ) t1
    on ( t1.CLE = v.CLE)
    when matched
    then update set
    NOM = :new.NOM
    when not matched
    then 
     insert (v.CLE, v.NOM) 
     values (:new.CLE, :new.NOM);
    end;
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

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

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Ok je mettrai mon code dans les balises qu'il faut. Désolé.

    Par contre ta solution ne fonctionne pas. J'ai l'impression que c'est soit un problème de configuration d'Oracle soit un bug...

    Merci de ton aide.

  4. #4
    Xo
    Xo est déconnecté
    Expert confirmé
    Avatar de Xo
    Inscrit en
    Janvier 2005
    Messages
    2 701
    Détails du profil
    Informations personnelles :
    Âge : 50

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 701
    Points : 4 238
    Points
    4 238
    Par défaut
    Faire un MERGE en PL/SQL me paraît un peu tiré par les cheveux, pourquoi ne pas faire un simple SELECT, et gérer la présence ou l'absence de l'enregistrement recherché par un INSERT ou un UPDATE ?
    "Ce que l'on conçoit bien s'énonce clairement,
    Et les mots pour le dire arrivent aisément." Nicolas Boileau

    "Expliquer empêche de comprendre si cela dispense de chercher"

    Quiz Oracle : venez tester vos connaissances !

    La FAQ Oracle : 138 réponses à vos questions
    Aidez-nous à la compléter

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    c'est pas plutôt AFTER INSERT pour avoir le :new ?

    Xo Merge est plus performant et surtout c'est fait pour

  6. #6
    Xo
    Xo est déconnecté
    Expert confirmé
    Avatar de Xo
    Inscrit en
    Janvier 2005
    Messages
    2 701
    Détails du profil
    Informations personnelles :
    Âge : 50

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 701
    Points : 4 238
    Points
    4 238
    Par défaut
    Citation Envoyé par Fred_D
    Merge est plus performant
    OK, ça paraît logique ...
    Citation Envoyé par Fred_D
    surtout c'est fait pour
    Oui, je sais, c'est même dans la FAQ
    "Ce que l'on conçoit bien s'énonce clairement,
    Et les mots pour le dire arrivent aisément." Nicolas Boileau

    "Expliquer empêche de comprendre si cela dispense de chercher"

    Quiz Oracle : venez tester vos connaissances !

    La FAQ Oracle : 138 réponses à vos questions
    Aidez-nous à la compléter

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

Discussions similaires

  1. probleme charset oracle php
    Par mickjack dans le forum Oracle
    Réponses: 7
    Dernier message: 19/10/2011, 17h03
  2. [pl/sql] probleme trigger oracle
    Par john123 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 06/12/2007, 19h27
  3. [Probleme Format] Trigger Oracle 10g
    Par Salmiok dans le forum Oracle
    Réponses: 1
    Dernier message: 10/05/2007, 21h17
  4. [JDBC]Probleme avec trigger Oracle
    Par aurel89 dans le forum JDBC
    Réponses: 2
    Dernier message: 02/08/2005, 11h53
  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