【问题标题】:PLSQL trigger - update records based on select queryPLSQL 触发器 - 基于选择查询更新记录
【发布时间】: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 上

标签: plsql triggers


【解决方案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 谢谢你,这就是我想要的!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-09-13
  • 1970-01-01
相关资源
最近更新 更多