首页 > 解决方案 > MySQL触发器以列的属性为目标

问题描述

我正在处理与我的数据库中的人打交道的重叠超级/子类型关系。我想做的是让重叠的子类型在超类型获得新行时插入新行。我已附上我的 LRD 以澄清这种关系。LRD 我想创建一个触发器,根据人员表中的雇员/用户属性将新人员行插入正确的子类型。到目前为止,我尝试的代码在向人员插入行时出现错误,指出“员工列不存在”。我认为这是因为该代码试图将 if 语句用于实际上不存在的子类型。

我将不胜感激任何反馈。表详细信息

    CREATE TABLE PERSON
(person_id int(10) not null AUTO_INCREMENT,
first_name varchar(15) not null,
last_name varchar(15) not null,
employee char(1),
participant char(1),
CONSTRAINT person_pk PRIMARY KEY (person_id))
ENGINE=InnoDB;

CREATE TABLE EMPLOYEE
(eperson_id int(10) not null AUTO_INCREMENT,
enterprise_email varchar(30),
manager_id int(10),
CONSTRAINT employee_pk PRIMARY KEY (eperson_id),
CONSTRAINT employee_fk1 FOREIGN KEY(eperson_id) REFERENCES PERSON(person_id) ON update cascade,
CONSTRAINT employee_fk2 FOREIGN KEY(manager_id) REFERENCES EMPLOYEE(eperson_id) ON update cascade)
ENGINE=InnoDB;

 CREATE TABLE PARTICIPANT
(pperson_id int(10) not null AUTO_INCREMENT,
city varchar(30),
state varchar(2),
zip int(5),
sign_up_date date,
termination_date date,
CONSTRAINT participant_pk PRIMARY KEY (pperson_id),
CONSTRAINT participant_fk FOREIGN KEY(pperson_id) REFERENCES PERSON(person_id) ON update cascade)
ENGINE=InnoDB;

触发代码

 DELIMITER //
    CREATE TRIGGER subtype_creator
    AFTER INSERT ON PERSON 
    FOR EACH ROW 
BEGIN
    IF  (employee = ‘e’ ) THEN
    INSERT INTO EMPLOYEE
    SET eperson_id = NEW.person_id,
        last_name = NEW.last_name,
        enterprise_email = NULL,
        manager_id = NULL;
   IF  (participant = ‘p’ )THEN
  INSERT INTO PARTICIPANT
    SET pperson_id = NEW.person_id,
    city=NULL,
    state = NULL,
    zip = NULL,
    sign_up_date =NULL,
    termination_date = NULL;
    END IF;
END IF;
END//
DELIMITER ; 

标签: mysqltriggerssubtypesupertype

解决方案


这可能对你有用。

首先,我认为AUTO_INCREMENT在列上有属性EMPLOYEE.eperson_id并且PARTICIPANT.pperson_id不需要。

由于这两个列都是FOREIGN KEYS并且正在引用回 table 的person_idPERSON,因此它们需要并且将通过TRIGGER反正从该列获取它们的值,因此无需在表中自动递增它们。所以我会改变这一点。

TRIGGER应该适用于填充两个表格EMPLOYEE和表格PARTICIPANT之后:INSERTPERSON

DELIMITER //
    CREATE TRIGGER subtype_creator
    AFTER INSERT ON PERSON 
    FOR EACH ROW 
BEGIN
    INSERT INTO EMPLOYEE(eperson_id, enterprise_email, manager_id)
    VALUES(NEW.person_id, NULL, NULL);
    INSERT INTO PARTICIPANT(pperson_id, city, state, zip, sign_up_date, termination_date)
    VALUES(NEW.person_id, NULL, NULL, NULL, NULL, NULL);
END//
DELIMITER ;

希望这对您有所帮助。


推荐阅读