避免SQL Server 触发器死循环

        在使用SQL Server时,有时候希望针对数据表中某一字段的修改执行一段触发器代码,比如修改了人员名称时,我们希望数据库会自动执行一代码来修改同一数据表中的姓名拼音首字母字段。如果使用After Update触发器则会让SQL Server崩溃掉,那么有什么办法可以避免这种死循环吗?答案是肯定的,我可以在触发器中判断用户是否修改了姓名字段,如果是则执行后续更新代码,如果用户修改了其他字段,则不执行任何代码。 

        假设有一张表存储客户的信息,第一个字段是Visitor_ID,第二个字段Visitor_Name,第三个字段是Visitor_PY_Code。我们针对新增和更新动作写两个触发器。

        针对新增的触发器很容易写,现在的问题是在更新的触发器,如果再使用Update语句就会循环执行触发器了,系统会崩溃掉的。我们希望只针对单一字段的更新执行触发器。还好SQL提供了COLUMNS_UPDATED()函数,能够判断出哪一字段被更新。于是将更新的触发器写成如下:

CREATE   TRIGGER   [ UpdatePYCodeOnly ]   ON   [ dbo ] . [ Visitor ]  
FOR   UPDATE
AS
IF  (COLUMNS_UPDATED()  &   2 =   2   BEGIN
declare
  
@VisitorID   int ,
  
@NameStr   nvarchar ( 50 )
  
Select   @VisitorID   =  Visitor_ID,  @NameStr   =  Visitor_Name  From  Inserted
  
Update  Visitor  Set  NamePINYIN  =  dbo.GetPYCode( @NameStr Where  Visitor_ID  =   @VisitorID
END

        在使用COLUMNS_UPDATED()函数需要注意以下几点

  1. 表中第一个字段序号为0,第二个字段序号为1,依此类推
  2. 表中的字段顺序不要改动

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值