zoukankan      html  css  js  c++  java
  • SET XACT_ABORT各种用法及显示结果

    使用MSSQL事务回滚总结
     1.默认为SET XACT_ABORT OFF 即遇到错误时回滚(真是晕,这不叫回滚,遇到错误当然不能执行了)所以干脆说默认回滚不起作用。
     2.SET XACT_ABORT ON 
       。。。
      COMMIT TRAN
      这时才是所谓真正的事务,遇到任何错误事务回滚
     3.SET XACT_ABORT OFF
       。。。
       这时遇到错误时事务回滚,错误前的操作正常

      另@@IDENTITY 系统产销
    ==============================
    理解 @@IDENTITY

    @@IDENTITY 返回最后一个插入 IDENTITY 的值,这些操作包括:INSERT, SELECT INTO,或者 bulk copy。如果在给没有 IDENTITY 列的其他表插入记录,系统将其置为 null。如果有多行记录插入到 IDENTITY 表中,@@IDENTITY 表示最后一个产生的值。如果触发了某个触发器,并且这个触发器执行向另一个带有 IDENTITY 列的表的插入操作,@@IDENTITY 将返回这个由触发器产生的值。如果这个触发器插入的表中不包含 IDENTITY 列,那么 @@IDENTITY 将为 null。如果插入操作失败,@@IDENTITY 值依然会增加,所以 IDENTITY 不保证数据的连续性。



    一、准备工作:

           1、首先我们创建测试数据库:

    create database demo

        2、创建数据表和测试数据:(这里注意外键控制)

    use demo
    CREATE TABLE student
    (    
            stuid 
    int NOT NULL PRIMARY KEY,
            stuname 
    varchar(50)
    )
    CREATE TABLE score 
    (
            stuid 
    int NOT NULL REFERENCES student(stuid),
            score 
    int
    )
    GO

    INSERT INTO student VALUES (101,'zhangsan'
    INSERT INTO student VALUES (102,'wangwu'
    INSERT INTO student VALUES (103,'lishi'
    INSERT INTO student VALUES (104,'maliu'

    GO

    二、各种用法及输出结果:

          1、语句1:

    use demo

    --Invoking a run-time error
    SET XACT_ABORT OFF
    BEGIN TRAN
        
    INSERT INTO score  VALUES (101,90)
        
    INSERT INTO score VALUES (102,78
        
    INSERT INTO score VALUES (107,76/* Foreign Key Error */ 
        
    INSERT INTO score VALUES (103,81
        
    INSERT INTO score VALUES (104,65
    COMMIT TRAN
    go

          结果1:只回滚错误行,语句还继续执行。

    --select * from score
    101    90
    102    78
    103    81
    104    65

          2、语句2:

    use demo

    --事务回滚
    SET XACT_ABORT on
    BEGIN TRAN
        
    INSERT INTO score  VALUES (101,90)
        
    INSERT INTO score VALUES (102,78
        
    INSERT INTO score VALUES (107,76/* Foreign Key Error */ 
        
    INSERT INTO score VALUES (103,81
        
    INSERT INTO score VALUES (104,65
    COMMIT TRAN
    go

          结果2:事务终止并全部回滚,结果为空。

    --select * from score

          3、语句3:

    use demo

    --事务在错误行终止,错误行回滚,错误行之前的不回滚
    SET XACT_ABORT on
    BEGIN
    INSERT INTO score  VALUES (101,90)
        
    INSERT INTO score VALUES (102,78
        
    INSERT INTO score VALUES (107,76/* Foreign Key Error */ 
        
    INSERT INTO score VALUES (103,81
        
    INSERT INTO score VALUES (104,65
    END
    go

          结果3:出现这种是因为系统把每个insert语句都看成是单独的事务,所以错误行以前的是不回滚的。

    --select * from score
    101    90
    102    78
    以上转载自:http://www.cnblogs.com/wdx2008/archive/2007/12/19/1005196.html
    原文有一个错误,已经改正。。。。。。。。
    另外附上自已写的一个存储过程
    SQL-CODE/*
     *Author:董广祥
     *Date:2009/9/5
    */
    create proc usp_Insert_sConfig
    @IndCoope nvarchar(50),
    @UserID nvarchar(20),
    @UserName nvarchar(20),
    @UserPwd nvarchar(50),
    @GrpID int,
    @Closed bit
    as
    if not exists(select ID from [dbo].[sConfig] where [IndCoope] = @IndCoope)
    begin
     SET XACT_ABORT ON
     begin tran
      INSERT INTO [dbo].[sConfig] ([IndCoope])
      VALUES(@IndCoope)
      begin
       if not exists(select userid from sloguser where userid=@userid)
       begin
        INSERT INTO sLogUser (UserID, UserName, UserPwd, GrpID, Closed,Inc_Id)
        VALUES (@UserID,@UserName,@UserPwd,@GrpID,@Closed,SCOPE_IDENTITY())
       end
      end
     commit tran
    end

  • 相关阅读:
    12个国外优秀.Net开源项目
    CYQ.Data 轻量数据层之路 V4.3 版本发布[增加对SQLite,MySQL数据库的支持]
    秋色园QBlog V2.5 后台管理系统源码发布下载
    秋色园QBlog技术原理解析:认识整站处理流程(二)
    CYQ.Data 数据框架 加快开源速度 发布V1.5.5版本源码
    秋色园[CYQ.Data]开源团队寻人
    秋色园QBlog技术原理解析:页面内容填充及多语言翻译流程演示示例(十)
    CYQ.Data 数据框架 性能评测
    框架设计:实现数据的按需更新与插入的改进
    秋色园QBlog技术原理解析:Module之基类生命周期页面加载(七)
  • 原文地址:https://www.cnblogs.com/myssh/p/1560702.html
Copyright © 2011-2022 走看看