我认为我不同意您对触发器要执行的操作的描述。在我看来,它旨在执行此业务规则:对于给定的t1_appnt_event值,一次只有一行可以具有t1_prnt_t1_pk的非NULL值。(它们是否在第二列中具有相同的值都没有关系。)
有趣的是,它是为UPDATE OF t1_appnt_event而不是其他列定义的,因此我认为有人可以通过更新第二列来打破规则,除非该列有单独的触发器。
您可能有一种方法可以创建一个基于函数的索引来强制执行此规则,以便完全摆脱触发器。我想出了一种方法,但是需要一些假设:
如果这些假设成立,则可以创建如下函数:
dev> create or replace function f( a number, b number ) return number deterministic as
2 begin
3 if a is null then return 0-b; else return a; end if;
4 end;
和这样的索引:
CREATE UNIQUE INDEX my_index ON my_table
( t1_appnt_event, f( t1_prnt_t1_pk, primary_key_column) );
因此,PMNT列为NULL的行将出现在索引中,并且主键的倒数为第二个值,因此它们永远不会相互冲突。不为NULL的行将使用列的实际(正)值。违反约束的唯一方法是,如果两行中的两行都具有相同的非NULL值。
这可能是“聪明”的做法,但它可能会帮助您解决问题。
Paul Tomblin的更新:我继续更新了igor在评论中提出的原始想法:
CREATE UNIQUE INDEX cappec_ccip_uniq_idx
ON tbl1 (t1_appnt_event,
CASE WHEN t1_prnt_t1_pk IS NOT NULL THEN 1 ELSE t1_pk END);