欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

[點晴永久免費OA]SET XACT_ABORT各種用法及顯示結果

Ccoffee
2024年6月17日 15:54 本文熱度 1313
:SET XACT_ABORT各種用法及顯示結果


使用MSSQL事務回滾總結
 1.默認為SET XACT_ABORT OFF 即遇到錯誤時回滾(真是暈,這不叫回滾,遇到錯誤當然不能執行了)所以干脆說默認回滾不起作用。
 2.SET XACT_ABORT OFF
   。。。
  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

轉載于:https://www.cnblogs.com/wdx2008/archive/2007/12/19/1005196.html


該文章在 2024/6/17 15:54:55 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved