【发布时间】:2022-01-01 22:12:42
【问题描述】:
我正在尝试消除空值而不使列“非空”以避免错误。因此,我想创建一个触发器来更新每个插入的行,如果它包含 null 以将其替换为“N”。以下语法导致
“作为单个语句执行。失败 [5423 : HY000] 此触发器包含无效的 REFERENCING 子句。 经过时间 = 00:00:00.018 声明 1:替换失败。 "
语法:
Replace TRIGGER DB.C_UP_CLIENTS
AFTER INSERT ON DB.CLIENTS
REFERENCING OLD table as old_clients_table
NEW table as new_clients_table
FOR EACH Statement
(update DB.CLIENTS set NEEDS_AUTHENTICATION = 'N' where NEEDS_AUTHENTICATION is null;);
【问题讨论】:
-
在 INSERT 触发器中不能有 OLD TABLE 引用,并且应该在触发器主体中使用 NEW TABLE 别名,而不是目标表本身。但是您的描述听起来像是带有 WHEN / SET 的 BEFORE INSERT ROW 触发器可能更适用。
标签: sql triggers teradata teradata-sql-assistant teradatasql