dadamoney

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
CREATE   TRIGGER   [Update_ChildWareID]   ON   [dbo].[t_goodlctn_std]    
  FOR     UPDATE  
  AS  
  declare   @Lctn_Order   int  
  declare   @OldWareID   int  
  declare   @NewWareID   int  
  declare   @strSql   varchar(8000)  
  declare   @Lctn_Id   varchar(50)  
  IF   Update(Ware_id)  
  Begin  
  select   @OldWareID=Ware_Id     from   deleted  
  select   @Lctn_ID=Lctn_ID,@NewWareID=ware_Id,@Lctn_order=lctn_order   from   inserted  
  if   @OldWareId<>@NewWareId  
  Begin  
  set   @strSql='update   t_goodlctn_std   set   ware_id='+cast(@NewWareID   as   varchar(10))+'where   '  
  select   @strSql=  
  Case    
  when   @Lctn_order=0   then   @strSql+'substring(Lctn_id,1,1)'  
  when   @Lctn_order=1   then   @strSql+'substring(Lctn_id,1,3)'  
  when   @Lctn_order=2   then   @strSql+'substring(Lctn_id,1,4)'  
  when   @Lctn_order=3   then   @strSql+'   Lctn_id'  
  End  
  set   @strSql=@strSql+'='+''''+@Lctn_id+''''  
  exec(@strSql)  
  End  
  End  
   
   
  CREATE   TABLE   [dbo].[t_goodlctn_std]   (  
  [lctn_id]   [varchar]   (30)   COLLATE   Chinese_PRC_CI_AS   NOT   NULL   ,  
  [lctn_name]   [varchar]   (30)   COLLATE   Chinese_PRC_CI_AS   NULL   ,  
  [length]   [decimal](10,   0)   NULL   ,  
  [width]   [decimal](10,   0)   NULL   ,  
  [high]   [decimal](10,   0)   NULL   ,  
  [goodtype_id]   [int]   NULL   ,  
  [hold_num]   [decimal](18,   0)   NULL   ,  
  [digt_id]   [int]   NULL   ,  
  [ware_id]   [int]   NULL   ,  
  [parent_lctn]   [varchar]   (30)   COLLATE   Chinese_PRC_CI_AS   NULL   ,  
  [lctn_order]   [smallint]   NOT   NULL    
  )   ON   [PRIMARY]  
   
  其中,Lctn_ID是有编码规则的.  
  仓库级:1位;       料斗2位;         层:1位;         货盒:2位  
  例如A01B01,代表:A号仓库,01号料斗,B层,01号货盒  
   
  现在要求当更改某级的记录的Ware_id时,要求下级也要随着更改,我采用了触发器,但是我现在不知道它具体的工作流程.举个例子来说:  
  有四条记录  
  Lctn_id                                 Ware_ID  
  A                                                 1  
  A01                                             1  
  A01B                                           1  
  A01B01                                       1  
   
  这样,如果更新第一条记录,Lctn_ID为A的Ware_id为2,则触发器将2,3,4的Ware_id都改成2,但是我想了一下这是个递归的调用,因为当触发器更新A01时,实际上又触发了Update触发器.......这肯定要花费时间,而我要求它只进行一次Update就可以了.  
   
  现在请问:1/我设计的触发器有没有问题?  
                    2/如果我的是正确的,如果实现禁用递归
1.
企业管理器->服务器->属性->服务器设置->允许激发会激发其它触发器(嵌套触发器)的触发器  
  勾上即可以嵌套,否则不会嵌套。
2.
你要设置允许递归才行     exec   sp_dboption   '库名','recursive   triggers','true'

3. 业管理器   右键   服务器-》属性-》服务器设置-》服务器行为-》去掉允许会激发其他触发器的触发器的选项   试试

4.和程序中的递归是一样的嘛   
    
无论你怎么写,都要用到递归算法,因为SQL不支持语句上的直接递归  
   
   
  嗯.我看了,现在确实是"允许嵌套"的设置.  
   
  你说要用到递归算法?这个我用其它的程序设计语言可以实现,用TSQL也可以吗???  
   
  能举个例子吗?  
   
  我从没想过TSQL也能用递归算法!

  create   proc   p_test  
  @a   int  
  as  
  if   @a<10  
  begin  
      set   @a=@a+1  
      exec   p_test   @a  
  end  
  go  
   
  --调用  
  exec   p_test   2
posted on 2007-03-29 09:19  dadamoney  阅读(586)  评论(0编辑  收藏  举报