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

SQL Oracle Discussion :

prob d'affectation des dates


Sujet :

SQL Oracle

  1. #1
    Membre régulier
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Points : 115
    Points
    115
    Par défaut prob d'affectation des dates
    Bonjour
    voila mon trigger :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE OR REPLACE TRIGGER trigger_date_maj BEFORE UPDATE OR INSERT ON PERSONNES
     FOR EACH ROW  DECLARE  date_m VARCHAR(20); 
    BEGIN 
    if (:new.date_maj is NOT NULL) then date_m := :new.date_maj ; 
    else
      if (:new.dat_creation is NOT NULL)
        then date_m := :new.dat_creation ; 
      else date_m:='01/01/1999';  
      end if ;
    end if ; 
    update personnes@dblink set date_maj = date_m where substr(id_personne,1,(length(id_personne)-1))= :new.id_personne ; END;
    et l'erreur :
    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
    Erreurs pour TRIGGER TRIGGER_DATE_MAJ :
     
    LINE/COL ERROR
    -------- -----------------------------------------------------------------
    7/18     PLS-00103: Symbole "01" rencontrÚ Ó la place d'un des symboles
             suivants :
             * & = - + ; < / > at in is mod remainder not rem
             <exposant (**)> <> or != or ~= >= <= <> and or like LIKE2_
             LIKE4_ LIKEC_ between || multiset member SUBMULTISET_
             Symbole "*" a ÚtÚ substituÚ Ó "01" pour continuer.
     
    7/28     PLS-00103: Symbole "" rencontrÚ Ó la place d'un des symboles
             suivants :
             * & = - + ; < / > at in is mod remainder not rem
             <exposant (**)> <> or != or ~= >= <= <> and or like LIKE2_
     
    LINE/COL ERROR
    -------- -----------------------------------------------------------------
             LIKE4_ LIKEC_ between || member SUBMULTISET_
             Symbole "*" a ÚtÚ substituÚ Ó "" pour continuer.
    j'avoue que je comprend plus rien la

  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
    Bizarre.
    Tes new.date_xxx sont des dates ou des varchar ?

    J'ai un peu simplifié le trigger :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE OR REPLACE TRIGGER trigger_date_maj 
    BEFORE UPDATE OR INSERT ON PERSONNES
    FOR EACH ROW 
    BEGIN 
     UPDATE personnes@dblink 
     SET date_maj = COALESCE(:NEW.date_maj, :NEW.dat_creation, '01/01/1999')
     WHERE SUBSTR(id_personne,1,LENGTH(id_personne)-1)= :NEW.id_personne ;
    END;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE OR REPLACE TRIGGER trigger_date_maj 
    BEFORE UPDATE OR INSERT ON PERSONNES
    FOR EACH ROW 
    BEGIN 
     UPDATE personnes@dblink 
     SET date_maj = NVL(:NEW.date_maj, NVL(:NEW.dat_creation, '01/01/1999'))
     WHERE SUBSTR(id_personne,1,LENGTH(id_personne)-1)= :NEW.id_personne ;
    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
    Membre régulier
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Points : 115
    Points
    115
    Par défaut
    oui , de type Date

  4. #4
    Membre régulier
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Points : 115
    Points
    115
    Par défaut
    quand j'execute le trigger tout seul , ca passe
    mais dés que je l'integre dans ma procedure , ca déconne
    voila la partie ou j'integer le trigger :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    if ( date_modif is NOT NULL ) then 
     
    trigger_date_maj :='CREATE OR REPLACE TRIGGER trigger_date_maj BEFORE UPDATE OR INSERT ON PERSONNES FOR EACH ROW  DECLARE  date_m VARCHAR(20); BEGIN update '||t||'@'||nomBase||' SET date_modif = NVL(:new.date_maj, NVL(:new.dat_creation, ''01/01/1999'')) where substr('||key||',1,(length('||key||')-1))= :new.id_personne ; 
    END;';
     
    execute immediate trigger_date_maj;
    end if ;

  5. #5
    Membre régulier
    Inscrit en
    Juin 2007
    Messages
    328
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 328
    Points : 115
    Points
    115
    Par défaut
    Merci au faite ca marche mnt j'au du concatenener le contenu de la variable date_modif et non pas la mettre sans "||"
    bonne journée a tous

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

Discussions similaires

  1. Saisie des dates
    Par J-P-B dans le forum XMLRAD
    Réponses: 5
    Dernier message: 04/07/2003, 11h08
  2. Manipuler des dates...
    Par Ti Jen-tsie dans le forum Langage
    Réponses: 4
    Dernier message: 26/06/2003, 11h46
  3. [MCD] [MCD] Gestion des dates
    Par brionne dans le forum Schéma
    Réponses: 3
    Dernier message: 30/05/2003, 13h01
  4. Réponses: 3
    Dernier message: 19/03/2003, 15h19
  5. Fonctions de manipulation des chaines et des dates
    Par Fares BELHAOUAS dans le forum Débuter
    Réponses: 3
    Dernier message: 09/11/2002, 22h43

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