开启事务
添加一条记录
执行存储过程SPTest 参数为添加记录的ID
抛出一个错误
事务回滚那么这里回滚后,SPText的存储过程操作会不会回滚呢谢谢

解决方案 »

  1.   


    --看帮助,解释很清楚
    SET QUOTED_IDENTIFIER OFF;
    GO
    SET NOCOUNT OFF;
    GO
    USE AdventureWorks;
    GO
    CREATE TABLE TestTrans(Cola INT PRIMARY KEY,
                   Colb CHAR(3) NOT NULL);
    GO
    CREATE PROCEDURE TransProc @PriKey INT, @CharCol CHAR(3) AS
    BEGIN TRANSACTION InProc
    INSERT INTO TestTrans VALUES (@PriKey, @CharCol)
    INSERT INTO TestTrans VALUES (@PriKey + 1, @CharCol)
    COMMIT TRANSACTION InProc;
    GO
    /* Start a transaction and execute TransProc. */
    BEGIN TRANSACTION OutOfProc;
    GO
    EXEC TransProc 1, 'aaa';
    GO
    /* Roll back the outer transaction, this will
       roll back TransProc's nested transaction. */
    ROLLBACK TRANSACTION OutOfProc;
    GO
    EXECUTE TransProc 3,'bbb';
    GO
    /* The following SELECT statement shows only rows 3 and 4 are 
       still in the table. This indicates that the commit
       of the inner transaction from the first EXECUTE statement of
       TransProc was overridden by the subsequent rollback. */
    SELECT * FROM TestTrans;
    GO
     SQL Server Database Engine 将忽略内部事务的提交。根据最外部事务结束时采取的操作,将提交或者回滚内部事务。如果提交外部事务,也将提交内部嵌套事务。如果回滚外部事务,也将回滚所有内部事务,不管是否单独提交过内部事务。对 COMMIT TRANSACTION 或 COMMIT WORK 的每个调用都应用于最后执行的 BEGIN TRANSACTION。如果嵌套 BEGIN TRANSACTION 语句,那么 COMMIT 语句只应用于最后一个嵌套的事务,也就是在最内部的事务。即使嵌套事务内部的 COMMIT TRANSACTION transaction_name 语句引用外部事务的事务名称,该提交也只应用于最内部的事务。ROLLBACK TRANSACTION 语句的 transaction_name 参数引用一组命名嵌套事务的内部事务是非法的,transaction_name 只能引用最外部事务的事务名称。如果在一组嵌套事务的任意级别执行使用外部事务名称的 ROLLBACK TRANSACTION transaction_name 语句,那么所有嵌套事务都将回滚。如果在一组嵌套事务的任意级别执行没有 transaction_name 参数的 ROLLBACK WORK 或 ROLLBACK TRANSACTION 语句,那么所有嵌套事务都将回滚,包括最外部事务。@@TRANCOUNT 函数记录当前事务的嵌套级别。每个 BEGIN TRANSACTION 语句使 @@TRANCOUNT 增加 1。每个 COMMIT TRANSACTION 或 COMMIT WORK 语句使 @@TRANCOUNT 减去 1。没有事务名称的 ROLLBACK WORK 或 ROLLBACK TRANSACTION 语句将回滚所有嵌套事务,并使 @@TRANCOUNT 减小到 0。使用一组嵌套事务中最外部事务的事务名称的 ROLLBACK TRANSACTION 将回滚所有嵌套事务,并使 @@TRANCOUNT 减小到 0。在无法确定是否已经在事务中时,可以用 SELECT @@TRANCOUNT 确定 @@TRANCOUNT 是等于 1 还是大于 1。如果 @@TRANCOUNT 等于 0,则表明不在事务中。
      

  2.   

    我的环境是这样的
    事务开始
     添加一条记录
     执行存储过程SPTest
     抛出错误
     回滚事务
    结束事务SpTest内容
    启动事务
      删除记录
    提交事务
    ----------------------------
    我这里问,如果我的事务回滚后,SPTest的事务会不会回滚啊
      

  3.   

    做个测试不就知道了create procedure udp_insert
    as
    begin
    insert b select 1
    end
    go
    create table b
    (a int)
    go
    create  unique index IX_a on b(a)
    go
    begin tran
    begin try
    insert b select 1
    exec udp_insert
    commit
    end try
    begin catch
    rollback
    end catchselect * from bdrop table b
    drop procedure udp_insertb表没有数据
    回滚了