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

Bases de données Delphi Discussion :

[BDE][ORACLE] Créer un trigger depuis un TQuery


Sujet :

Bases de données Delphi

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut [BDE][ORACLE] Créer un trigger depuis un TQuery
    Bonjour,

    Je cherche à créer un trigger (gestion auto-incrément) depuis une application en Delphi.

    La syntaxe du trigger qui fonctionne sous ORACLE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    create trigger fzj.TB_EMPLOYEE_TRIG_BI before insert on fzj.Tb_Employee
    for each row
    begin
     select fzj.TB_EMPLOYEE_SEQ.nextval into :new.Employee_id from dual;
    end;
    /
    Depuis un TQuery la même instruction échoue et me retourne un message :
    Le champ new.Employee_id est de type inconnu.

    Peut-on créer des trigger Oracle depuis Delphi ?
    Si oui depuis un TQuery ?

    Merci,

    a+

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut
    Je suis en forme aujourd'hui alors je m'auto-répond :

    En exécutant la même instruction via TDatabase.Execute(SQL: string)... ca fonctionne...

    Merci

    a+

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut
    En fait non, mon problème n'est pas résolu. Je n'ai plus de message d'erreur à la création du trigger depuis Delphi.

    Mais lors de l'insertion de données dans la table j'ai le message :
    SQL> insert into fzj2.TBDGender (Gender) VALUES ('Homme');
    insert into fzj2.TBDGender (Gender) VALUES ('Homme')
    *
    ERREUR à la ligne 1 :
    ORA-04098: Déclencheur 'FZJ2.TBDGENDER_TRIG_BI' non valide. Echec de la
    revalidation
    remarque : oui oui c'est pas la même table que tout à l'heure... mais le problème est le même...

    Si depuis ORACLE je recopie le code du trigger pour le régénérer... le trigger fonctionne...

    a+

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut
    OK, on oublie toute... erreur de syntaxe, le problème était entre l'écran et le clavier...

    Fallait pas mettre le "/" finale depuis Delphi !

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

Discussions similaires

  1. [applet] créer un fichier depuis une applet.
    Par BouB dans le forum Applets
    Réponses: 12
    Dernier message: 02/04/2007, 06h45
  2. [Oracle] Copie LONG RAW depuis un TRIGGER
    Par DarkBassRider dans le forum Oracle
    Réponses: 1
    Dernier message: 09/08/2006, 20h22
  3. [CVS] Créer une branche depuis Eclipse
    Par leminipouce dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 27/01/2006, 10h59
  4. Créer un trigger "before insert" avec SQL Server
    Par bubi dans le forum Développement
    Réponses: 2
    Dernier message: 14/11/2005, 10h12
  5. Connexion BDE oracle
    Par camis dans le forum Bases de données
    Réponses: 3
    Dernier message: 20/10/2004, 10h06

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