日期:2014-05-18  浏览次数:20671 次

触发器的问题?
各位大侠,我写了一个触发器,但一执行,发现,触发器的里面的语句全部执行成功了,但我的表没有执行成功,不知道什么原因?

如下:SMCustomer,PersonalINfo,CustomizeProduct都Insert成功了,
        但ICCard里面确没有Insert成功


--   =============================================
--   Create   basic   Instead   Of   Trigger
--   =============================================
IF   EXISTS   (SELECT   name  
      FROM       sysobjects  
      WHERE     name   =   N 'Tr_IC_Ins_SmCus '  
      AND       type   =   'TR ')
        DROP   TRIGGER   Tr_IC_Ins_SmCus
GO

CREATE   TRIGGER   Tr_IC_Ins_SmCus
ON   ICCard
INSTEAD   OF   INSERT
AS
BEGIN


    DECLARE   @SmCustomerOID   int,@SmPersonalInfoOID   int,@CustomizeProductOID   int,@ProductOID   int

    --增加短信用户SMCustomer
    INSERT   INTO   SmCustomer(CustomerOID,CustomerID,CustomerName,Telephone,CustomerTypeOID,CardNo,Active)
                                    SELECT   Cus.CustomerOID,Cus.CustomerID,Cus.[Name],Cus.Mobile,Cus.CustomerTypeOID,ins.CardNo,1
                                          FROM   inserted   Ins  
                                                      Inner   Join   Account   Acc   ON   Ins.AccountOID=Acc.AccountOID
                                                      Inner   Join   Customer   Cus   ON   Acc.CustomerOID=Cus.CustomerOID


    --增加个人信息定制三个月    
--     EXEC   GETOID   @SmPersonalInfoOID   OUTPUT  

    update   SequenceNo   set   nextNo=nextNo+1
    SET   @SmPersonalInfoOID=(Select   nextNo   from   SequenceNo)

    INSERT   INTO   SmPersonalInfo   (SmPersonalInfoOID,CustomerOID,PersonalInfoStatus,OperatorOID,UpdateDateTime,PIStartDate,PIEndDate)  
                                    SELECT     @SmPersonalInfoOID,SmCus.CustomerOID,1,Null,GetDate(),Convert(DateTime,Convert(Char(10),GETDATE(),120)),DateAdd(MM,3,Convert(DateTime,Convert(Char(10),GETDATE(),120)))
                                          FROM   inserted   Ins  
                                                      Inner   Join   Account   Acc   ON   Ins.AccountOID=Acc.AccountOID