触发器实现对插入数据的字段更改 Oracle+SQL Server

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了触发器实现对插入数据的字段更改 Oracle+SQL Server相关的知识,希望对你有一定的参考价值。

最近有个使用触发器实现对插入数据的某个列做更改的需求,因此整理了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触发器很难实现的功能。

以上是关于触发器实现对插入数据的字段更改 Oracle+SQL Server的主要内容,如果未能解决你的问题,请参考以下文章

Oracle 触发器将所有插入/更新写入文件

Oracle 触发器在插入或更新时更新字段

怎么实现对SQL Server数据库的字段进行加密和解密

Oracle实现主键字段自增

Oracle里面想实现自动插入递增的序号

oracle创建触发器(例:当有操作x_yonghu表指定字段并且字段有修改时,插入日志表)