mysql - 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 ;
解决方案
这可能对你有用。
首先,我认为AUTO_INCREMENT
在列上有属性EMPLOYEE.eperson_id
并且PARTICIPANT.pperson_id
不需要。
由于这两个列都是FOREIGN KEYS
并且正在引用回 table 的person_id
列PERSON
,因此它们需要并且将通过TRIGGER
反正从该列获取它们的值,因此无需在表中自动递增它们。所以我会改变这一点。
这TRIGGER
应该适用于填充两个表格EMPLOYEE
和表格PARTICIPANT
之后:INSERT
PERSON
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 ;
希望这对您有所帮助。
推荐阅读
- python-3.x - 共享服务帐户密钥是使用 Google 表格在工作组之间共享数据的可行方法吗?有没有更好的办法?
- javascript - 确保在 API 中的任何函数之前调用启动/初始化函数
- firebase - 我如何添加加载圆形图标,因为从 Firestore 获取数据需要时间?
- ansible - 读取所有变量和事实并将它们设置为 linux 环境变量
- unix - awk hack 根据计数进行破解
- sql - 有没有办法在 SQL (BigQuery) 上加入两个查询
- r - ggplot2 - 将平均值添加到我的置信区间
- excel - 使用 Excel 和 PowerQuery 设计大规模考勤系统
- javascript - 为什么 Firefox 控制台只引用一些对象键?
- android - 无法在 Google Play 控制台中停用已关闭 (Alpha) 的曲目