删除会员所有信息的触发器

之前,在项目的管理员后台删除会员信息的时候,要求与会员相关的所有表信息删除。这里的删除,指的都是逻辑删除,即将记录的状态置为删除状态,不是从数据库直接删除的物理删除。尽管最后项目经理要求不采用触发器的方案,采用在程序端置状态的方式来实现,还是来mark一下,就算是对Sql server触发器复习一下吧。

该触发器的代码如下所示:

   1: ---在membership会员信息表里面删除指定membershipid的企业会员时(实际上没有进行物理删除,只是将status置为-1)
   2: ---将与企业会员有关的信息表里面的相关信息进行逻辑删除,即status置为-1
   3: If Exists(Select 1 From sys.triggers Where name='membership_update')
   4:     Drop  Trigger membership_update 
   5: Go
   6: create trigger membership_update
   7: on Membership
   8: for update
   9: as
  10: begin
  11: declare @membershipid as int,@status as int
  12: select @membershipid=Membershipid,@status=Status from inserted;
  13: if @status=-1
  14:  begin
  15:        update company set status=@status where membershipid=@membershipid;
  16:        update supply set status=@status where membershipid=@membershipid;
  17:        update buy set status=@status where membershipid=@membershipid;
  18:        update companynews set status=@status where membershipid=@membershipid;
  19:        update honor set status=@status where membershipid=@membershipid;
  20:        update friendlink set status=@status where membershipid=@membershipid;
  21:        update [message] set status=@status where membershipid=@membershipid;
  22:        update employment set status=@status where membershipid=@membershipid;
  23:        update notice set status=@status where membershipid=@membershipid;
  24:  end
  25: end
posted @ 2012-09-13 11:34  美梦成真  阅读(351)  评论(0编辑  收藏  举报