Spartakus Skrevet 14. november 2007 Del Skrevet 14. november 2007 (endret) 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 15. november 2007 av xtc Lenke til kommentar
roac Skrevet 15. november 2007 Del Skrevet 15. november 2007 Ikke noe godt svar, men det jeg lurer på er hvorfor du denormaliserer dataene og henter informasjon fra ordrehodet og legger det ned i ordrelinjene. For all del, det kan være gode grunner til det, men som oftest er det ikke Lenke til kommentar
Spartakus Skrevet 15. november 2007 Forfatter Del Skrevet 15. november 2007 (endret) 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 15. november 2007 av xtc Lenke til kommentar
roac Skrevet 15. november 2007 Del Skrevet 15. november 2007 (endret) insert into ... select er vel da det du trenger. Såvidt jeg husker kan :new aksesseres på samme måte som en tabell, og da er det bare en liten spørring for å gjøre det du ønsker Endret 15. november 2007 av roac Lenke til kommentar
Anbefalte innlegg
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 kontoLogg inn
Har du allerede en konto? Logg inn her.
Logg inn nå