这些是表格:
CREATE TABLE Staff
(
staffID INTEGER,
staffName VARCHAR(20),
staffSurname VARCHAR(20),
DOB DATE NOT NULL,
staffBranchNo INTEGER,
salary DECIMAL(5,2),
startDateOfWork DATE
);
ALTER TABLE Staff
ADD (CONSTRAINT staff_pk PRIMARY KEY(staffID));
CREATE TABLE Branch
(
branchNo INTEGER,
branchCity varchar(20),
branchTotalStaffNumber INTEGER
);
ALTER TABLE Branch
ADD (CONSTRAINT branch_pk PRIMARY KEY(branchNo));
我需要一个触发器,该触发器可以根据staffBranchNo来更新branchTotalStaffNumber,当添加新的工作人员时,将更新或删除现有的工作人员。
我尝试了一些触发器,但没有一个触发器包含我需要的三个操作。以下触发器不起作用。
CREATE OR REPLACE TRIGGER staff_trigger
BEFORE INSERT OR UPDATE OR DELETE ON Staff
FOR EACH ROW
BEGIN
CASE
WHEN INSERTING THEN
INSERT INTO branch (branchTotalStaffNumber)
VALUES(:NEW.branchTotalStaffNumber);
WHEN UPDATING THEN
UPDATE branch SET branchTotalStaffNumber = :NEW.branchTotalStaffNumber;
WHEN DELETING THEN
delete from branch where staffBranchNo = :new.branchTotalStaffNumber;
END CASE;
END;
/
你不应将其trigger
用于存储计算值。但是,如果你正在学习,那么请使用下面的代码(请参阅内联注释)
CREATE OR REPLACE TRIGGER staff_trigger
BEFORE INSERT OR UPDATE OR DELETE ON Staff
FOR EACH ROW
BEGIN
IF INSERTING THEN -- used IF . CASE usage is not allowed as IF
UPDATE branch SET branchTotalStaffNumber = branchTotalStaffNumber + 1
Where branchno = :new.staffBranchNo; -- used :new to identify the record
ELSIF UPDATING THEN
-- update the branch table only if staffBranchno is updated
-- adding one staff to the new branch
IF :new.staffBranchNo <> :old.staffBranchNo THEN
UPDATE branch SET branchTotalStaffNumber = branchTotalStaffNumber + 1
Where branchno = :new.staffBranchNo;
-- removing one staff from old branch
UPDATE branch SET branchTotalStaffNumber = branchTotalStaffNumber - 1
Where branchno = :old.staffBranchNo;
END IF;
ELSE -- IF DELETING can be omitted
-- removing one staff from branch for delete action
UPDATE branch SET branchTotalStaffNumber = branchTotalStaffNumber - 1
Where branchno = :old.staffBranchNo;
END IF;
END;
/
请注意,你还可以在其中使用OF
子句和列名来创建触发器。仅当提到的列onOF
子句的值更改时,它才会执行触发器。