Gå til innhold

Anbefalte innlegg

Hei

 

Har to tabeller, ORDER_HEAD og ORDER_LINE, disse er bundet sammen med kolonnen ORDER_ID (et ordre system)

 

Når det blir kjørt INSERT INTO på ORDER_LINE vil jeg at triggeren skal hente (oppdatere) en verdi (SYS_ID) fra ORDER_HEAD som settes ned på hver linje for den gjeldene ORDER_ID.

 

CREATE OR REPLACE TRIGGER TRIGGER_SYSID_FIX
AFTER INSERT ON ORDER_LINE
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
DECLARE
   sysId VARCHAR2(50) := (SELECT SYS_ID FROM ORDER_HEAD WHERE ORDER_ID = :NEW.ORDER_ID);
BEGIN UPDATE ORDER_LINE SET SYS_ID = sysId WHERE ORDER_ID = :NEW.ORDER_ID
END;

 

Har prøvd med forskjellige varianter, noen kompilerer men feiler under kjøring osv. Noen som skjønner hva som må til for at det skal fungere?

Endret av xtc
Lenke til kommentar
Videoannonse
Annonse

Skjønner poenget ditt, men i dette tilfellet er det nødvendig.

 

Edit:

CREATE OR REPLACE TRIGGER TRG_SYSID_FIX
BEFORE INSERT OR UPDATE ON ORDER_LINE
FOR EACH ROW
BEGIN SELECT SYSID INTO :NEW.SYSID FROM ORDER_HEAD WHERE ORDER_HEAD.ORDER_ID = :NEW.ORDER_ID;
END;

Endret av xtc
Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
  • Hvem er aktive   0 medlemmer

    • Ingen innloggede medlemmer aktive
×
×
  • Opprett ny...