gpt4 book ai didi

sql - Oracle:排除用于触发触发器的一列的更新

转载 作者:行者123 更新时间:2023-12-04 03:02:52 26 4
gpt4 key购买 nike

在 oracle 中,我可以指定列,这应该会引发触发器的触发:

create or replace trigger my_trigger
before update of col1, col2, col3 on my_table for each row
begin
// the trigger code will be executed only if col1 or col2 or col3 was updated
end;

现在我想执行以下操作:我不希望触发器在 时触发只有一个 列已更新。这怎么可能?

我可以列出除列之外的所有列,这些列不应引起触发器的触发。这对于有很多列的表来说是相当麻烦的。

另一种方法是像这样使用 UPDATING 函数:
if not updating('COL3') then ...

但是,如果我一次更改 COL1 和 COL3,则该语句的计算结果为 false。这不是我想要的,因为我想在 时限制执行只有一个 列 (COL3) 已更新。

最佳答案

你可以这样做:

create or replace trigger my_trigger
before update on my_table
for each row
declare
n_cols integer := 0;
begin
for r in (select column_name from all_tab_columns
where table_name = 'MY_TABLE'
and owner = 'MY_SCHEMA')
loop
if updating(r.column_name) then
n_cols := n_cols + 1;
exit when n_cols > 1;
end if;
end loop;
if n_cols > 1 then
do_something;
end if;
end;

虽然可能不是非常有效!

关于sql - Oracle:排除用于触发触发器的一列的更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1421645/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com