最近有个使用触发器实现对插入数据的某个列做更改的需求,因此整理了Oracle和SQL Server对于此类需求的触发器写法,本文仅提到了Insert触发器。
首先我们创建一张表:
--创建Test表 Create table test(id int primary key,name varchar(20),sex varchar(1),status int)
我们的目的是实现新插入的数据满足sex字段为null时就把status设为1的需求,可根据实际需要更改条件。
因此SQL Server的写法为:
Create trigger [dbo].[trg1] on [dbo].[test] for insert as Declare c cursor for select id,sex from inserted Declare @id int Declare @sex varchar(1) Open c FETCH NEXT FROM c INTO @id,@sex While @@FETCH_STATUS = 0 Begin if @sex is null update dbo.test set status=1 where [email protected] --这里使用主键进行更新以便效率最大化 FETCH NEXT FROM c INTO @id,@sex END CLOSE c DEALLOCATE c
Oracle的写法为:
Create or replace trigger trg1 before insert on test referencing new as new old as old for each row Begin if :old.sex is null then :new.status:=1; end if; End trg1;
也可以实现同样的功能。
总结与比较:
我们发现由于Oracle提供了before/after的触发器写法因此实现起来更为简单,而SQL Server只能依靠游标来实现,显然Oracle的实现办法更加简单明了。
但并不是说所有情况下Oracle的语法都更好,某些时候SQL Server的语法也可以实现Oracle触发器很难实现的功能。
时间: 2024-10-24 17:27:08