PLSQL 触发器 - 基于选择查询更新记录
Posted
技术标签:
【中文标题】PLSQL 触发器 - 基于选择查询更新记录【英文标题】:PLSQL trigger - update records based on select query 【发布时间】:2015-06-20 12:49:18 【问题描述】:我有三张桌子:
HouseMode:
mode_id (INT, PK)
switch (CHAR 1BYTE)
ModeDevices:
modedevice_id (INT, PK)
house_mode (INT, FK)
houseroomdevice (INT, FK)
HouseRoomDevices:
houseroomdevice_id (INT, PK)
switch (CHAR 1BYTE)
我想要一个触发器,在更新HouseMode
表中的开关后更新来自HouseRoomDevices
表的开关。
我的触发器:
CREATE OR REPLACE TRIGGER switch
BEFORE UPDATE
ON HouseMode
FOR EACH ROW
BEGIN
UPDATE houseroomdevices
SET switch = :NEW.switch
WHERE EXISTS(SELECT houseroomdevice_id FROM houseroomdevices INNER JOIN modedevices ON houseroomdevice = houseroomdevice_id WHERE house_mode = :NEW.mode_id);
END;
但是当我尝试更新记录时:
UPDATE HouseMode
SET switch = 1
WHERE mode_id = 1;
它会更新 HouseRoomDevices
表中的所有记录。
【问题讨论】:
相信它应该在更新后根据您的声明在 HouseMode 上 【参考方案1】:您的更新语句是错误的,因为您的 WHERE 条件始终为真。使用这个:
UPDATE houseroomdevices
SET switch = :NEW.switch
WHERE houseroomdevice_id IN (SELECT houseroomdevice FROM modedevices WHERE house_mode = :NEW.mode_id);
【讨论】:
Pavel,这是一个错误的语法。您必须使用子查询来实现。 好的,Oracle 不支持UPDATE .. JOIN
语法。此外,我实际上在 OP 发布的更新查询中没有看到任何问题,除了他的 ON 子句有点奇怪并且他应该使用 AFTER 触发器而他使用的是 BEFORE 触发器。
@PavelGatnar 谢谢你,这就是我想要的!以上是关于PLSQL 触发器 - 基于选择查询更新记录的主要内容,如果未能解决你的问题,请参考以下文章
如果 Column_X 更新,PLSQL 触发器记录对审计表的更新
MySQL触发器:更新一张表中的记录,其中同一行中的记录匹配选择查询
Oracle-4 - :超级适合初学者的入门级笔记:plsql,基本语法,记录类型,循环,游标,异常处理,存储过程,存储函数,触发器