Warm tip: This article is reproduced from serverfault.com, please click

sql-有什么方法可以创建此触发器,还是应该使用其他方法?

(sql - Is there any way to create this trigger or should I use something else?)

发布于 2020-12-07 18:26:27

这些是表格:

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;
/
Questioner
zeynep
Viewed
0
Popeye 2020-12-08 09:23:35

你不应将其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子句的值更改时,它才会执行触发器