亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > SQL Server 2005 中使用 Try Catch 處理異常

SQL Server 2005 中使用 Try Catch 處理異常

熱門標簽:電銷機器人虛擬號碼 松原導航地圖標注 九鹿林外呼系統(tǒng)怎么收費 海南自動外呼系統(tǒng)價格 創(chuàng)業(yè)電銷機器人 滄州營銷外呼系統(tǒng)軟件 沈陽智能外呼系統(tǒng)代理 浙江地圖標注 舞鋼市地圖標注app

TRY...CATCH是Sql Server 2005/2008令人印象深刻的新特性.提高了開發(fā)人員異常處理能力.沒有理由不嘗試一下Try.. Catch功能.

* TRY 塊 - 包含可能產生異常的代碼或腳本
* CATCH 塊 - 如果TRY塊出現異常,代碼處理流將被路由到CATCH塊.在這里你可以處理異常,記錄日志等.
Sql Server中的Try Catch和C#,JAVA等語言的處理方式一脈相承.這種一致性才是最大的創(chuàng)新之處.

一、SQL SERVER 2000中異常處理

CREATE PROC usp_AccountTransaction 
 
  @AccountNum INT, 
 
  @Amount DECIMAL 
 
AS 
 
BEGIN 
 
  BEGIN TRANSACTION --beginning a transaction.. 
 
    UPDATE MyChecking SET Amount = Amount - @Amount 
 
      WHERE AccountNum = @AccountNum 
 
    IF @@ERROR != 0 --check @@ERROR variable after each DML statements.. 
 
    BEGIN 
 
      ROLLBACK TRANSACTION --RollBack Transaction if Error.. 
 
      RETURN 
 
    END 
 
    ELSE 
 
    BEGIN 
 
      UPDATE MySavings SET Amount = Amount + @Amount 
 
        WHERE AccountNum = @AccountNum 
 
      IF @@ERROR != 0 --check @@ERROR variable after each DML statements.. 
 
      BEGIN 
 
        ROLLBACK TRANSACTION --RollBack Transaction if Error.. 
 
        RETURN 
 
      END 
 
      ELSE 
 
      BEGIN 
 
        COMMIT TRANSACTION --finally, Commit the transaction if Success.. 
 
        RETURN 
 
      END 
 
    END 
 
END 
 
GO 

上面是Sql server 2000的一個存儲過程,在每個數據庫操作之后立即必須檢查@@ERROR,進行Commit / RollBack該事務.
Sql server 2000中監(jiān)測錯誤,只能通過監(jiān)測全局遍歷 @@ERROR.由于@@ERROR會被下一個數據庫操作所覆蓋. 所以在每次操作完后必須立即監(jiān)測.

二、SQL SERVER 2005中異常處理

TRY...CATCH是SQL Server 2005提供的更具有可讀性的語法.每個開發(fā)人員都熟悉這種寫法.SQL Server 2005仍然支持@@ERROR這種用法.

1.try catch語法:

BEGIN TRY 
 
  Try Statement 1 
 
  Try Statement 2 
 
  ... 
 
  Try Statement M 
 
END TRY 
 
BEGIN CATCH 
 
  Catch Statement 1 
 
  Catch Statement 2 
 
  ... 
 
  Catch Statement N 
 
END CATCH 

2.獲得錯誤信息的函數表:

下面系統(tǒng)函數在CATCH塊有效.可以用來得到更多的錯誤信息:

函數 描述

ERROR_NUMBER() 返回導致運行 CATCH 塊的錯誤消息的錯誤號。
ERROR_SEVERITY() 返回導致 CATCH 塊運行的錯誤消息的嚴重級別
ERROR_STATE() 返回導致 CATCH 塊運行的錯誤消息的狀態(tài)號
ERROR_PROCEDURE() 返回出現錯誤的存儲過程名稱
ERROR_LINE() 返回發(fā)生錯誤的行號
ERROR_MESSAGE() 返回導致 CATCH 塊運行的錯誤消息的完整文本

簡單示例:

BEGIN TRY 
 
  SELECT GETDATE() 
 
  SELECT 1/0--Evergreen divide by zero example! 
 
END TRY 
 
BEGIN CATCH 
 
  SELECT 'There was an error! ' + ERROR_MESSAGE() 
 
  RETURN 
 
END CATCH; 

3.try catch回滾/提交事務的示例

ALTER PROC usp_AccountTransaction 
 
  @AccountNum INT, 
 
  @Amount DECIMAL 
 
AS 
 
BEGIN 
 
  BEGIN TRY --Start the Try Block.. 
 
    BEGIN TRANSACTION -- Start the transaction.. 
 
      UPDATE MyChecking SET Amount = Amount - @Amount 
 
        WHERE AccountNum = @AccountNum 
 
      UPDATE MySavings SET Amount = Amount + @Amount 
 
        WHERE AccountNum = @AccountNum 
 
    COMMIT TRAN -- Transaction Success! 
 
  END TRY 
 
  BEGIN CATCH 
 
    IF @@TRANCOUNT > 0 
 
      ROLLBACK TRAN --RollBack in case of Error 
 
    -- you can Raise ERROR with RAISEERROR() Statement including the details of the exception 
 
    RAISERROR(ERROR_MESSAGE(), ERROR_SEVERITY(), 1) 
 
  END CATCH 
 
END 
 
GO

三、實例講解

創(chuàng)建錯誤日志表:

CREATE TABLE ErrorLog(errNum INT,ErrSev NVARCHAR(1000),ErrState INT,ErrProc NVARCHAR(1000),ErrLine INT, ErrMsg NVARCHAR(2000))

創(chuàng)建錯誤日志記錄存儲過程:

CREATE PROCEDURE ErrorLog
AS 
   SELECT ERROR_NUMBER() AS ErrNum,ERROR_SEVERITY()AS ErrSev,ERROR_STATE() AS ErrState,ERROR_PROCEDURE() AS ErrProc,ERROR_LINE()AS ErrLine,ERROR_MESSAGE()AS ErrMsg 
   INSERT 
   INTO ErrorLog 
   VALUES(ERROR_NUMBER(),ERROR_SEVERITY(),ERROR_STATE(),ERROR_PROCEDURE(),ERROR_LINE(),ERROR_MESSAGE())
GO

寫一個存儲過程吧!里面使用一下Try Catch:

USE [Your_Test]
GO
/****** Object: StoredProcedure [dbo].[getTodayBirthday]  
    Script Date: 05/17/2010 15:38:46 
    Author:jinho
    Desc:獲取當天生日的所有人
    ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[getTodayBirthday]
AS
BEGIN TRY
 declare @today datetime; 
 SET @today = GETDATE();--獲取今天的日期
 DECLARE @day VARCHAR(2);
 SET @day =REPLACE(DAY(@today),0,'');
 DECLARE @month VARCHAR(2) ;
 SET @month = REPLACE(month(@today),0,'');
 DECLARE @year VARCHAR(4);
 SET @year = YEAR(@today);
 SELECT * FROM dbo.UserInfo WHERE REPLACE(DAY(CONVERT(DATETIME,Birthday )),0,'') =@day AND REPLACE(MONTH(CONVERT(DATETIME,Brithday)),0,'')=@month AND Birthday IS NOT NULL 

 END TRY
 BEGIN CATCH
 ErrorLog --調用上面的存儲過程,保存錯誤日志
 END CATCH

說明:ERROR_NUMBER(),ERROR_SEVERITY(),ERROR_STATE(),ERROR_PROCEDURE(),ERROR_LINE(),ERROR_MESSAGE() 這幾個函數只能用在Catch里面!

您可能感興趣的文章:
  • SQL Server出現System.OutOfMemoryException異常的解決方法
  • 解決SQL SERVER數據庫備份時出現“操作系統(tǒng)錯誤5(拒絕訪問)。BACKUP DATABASE 正在異常終止。”錯誤的解決辦法
  • SQL Server自定義異常raiserror使用示例
  • SQLServer 連接異常與解決方法小結
  • SQLserver2000 企業(yè)版 出現"進程51發(fā)生了嚴重的異常"錯誤的處理方法
  • SqlServer異常處理常用步驟
  • SQL Server異常代碼處理的深入講解

標簽:日喀則 臺灣 咸寧 公主嶺 西藏 寶雞 海口 商洛

巨人網絡通訊聲明:本文標題《SQL Server 2005 中使用 Try Catch 處理異常》,本文關鍵詞  SQL,Server,2005,中,使用,Try,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 2005 中使用 Try Catch 處理異常》相關的同類信息!
  • 本頁收集關于SQL Server 2005 中使用 Try Catch 處理異常的相關信息資訊供網民參考!
  • 推薦文章
    精品国产一区二区三区久久久狼| 一本伊大人香蕉高清在线观看| 日韩中文字幕在线播放| 99色吧| 欧美一区二区三区在线观看| 欧美电影免费看大全| 亚飞与亚基在线观看| 日本在线不卡视频| 国产a免费观看| 亚洲精品中文一区不卡| 国产网站免费观看| 亚欧成人乱码一区二区| 国产麻豆精品高清在线播放| 国产一区二区精品尤物| 日本免费乱人伦在线观看 | 国产一区免费观看| 麻豆系列 在线视频| a级毛片免费全部播放| 国产a毛片| 四虎影视库| 午夜激情视频在线观看| 九九精品久久久久久久久| 成人a大片在线观看| 亚洲精品久久久中文字| 欧美爱色| 欧美大片a一级毛片视频| 精品视频免费在线| 国产不卡在线看| 99久久精品国产片| 国产成人啪精品| 香蕉视频一级| 欧美另类videosbestsex视频| 99色视频| 久草免费资源| 九九免费高清在线观看视频| 日韩中文字幕在线亚洲一区| 香蕉视频久久| 国产一区二区精品久| 成人影院久久久久久影院| 国产不卡在线观看| 精品视频在线看 | 欧美另类videosbestsex久久| 欧美国产日韩久久久| 国产麻豆精品高清在线播放| 日本免费看视频| 成人在免费观看视频国产| 99久久精品国产麻豆| 日本伦理片网站| 国产91精品露脸国语对白| 国产一区二区福利久久| 国产91丝袜在线播放0| 日日夜夜婷婷| 美女免费毛片| 天天色色网| 欧美a级片免费看| 精品国产三级a| 亚洲精品中文一区不卡| 国产网站免费在线观看| 国产综合91天堂亚洲国产| 一级毛片视频在线观看| 欧美爱色| 999久久久免费精品国产牛牛| 精品视频在线看| 日韩中文字幕一区| 午夜在线影院| 美女免费精品视频在线观看| 国产伦精品一区二区三区无广告 | 精品久久久久久中文| 欧美一级视| 日韩专区第一页| 四虎影视久久久免费| 国产伦精品一区二区三区无广告 | 国产高清在线精品一区二区| 国产高清在线精品一区a| 精品久久久久久免费影院| 精品国产一区二区三区免费| 午夜欧美成人香蕉剧场| 欧美1区| 亚洲精品永久一区| 中文字幕一区二区三区 精品| 在线观看成人网| 久久久成人网| 青青久久国产成人免费网站| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 香蕉视频久久| 国产国语在线播放视频| 国产一区免费在线观看| 日本伦理片网站| 国产网站免费视频| a级毛片免费观看网站| 高清一级片| 91麻豆爱豆果冻天美星空| 亚州视频一区二区| 精品国产亚洲人成在线| 精品视频在线观看视频免费视频 | 台湾美女古装一级毛片| 九九久久国产精品大片| 久久99这里只有精品国产| 国产原创中文字幕| 黄视频网站在线观看| 青草国产在线观看| 在线观看导航| 韩国毛片免费| 天天色成人网| 亚洲精品永久一区| 美国一区二区三区| a级毛片免费全部播放| a级毛片免费全部播放| 日本特黄特黄aaaaa大片| 国产一区二区精品久久91| 精品国产亚洲人成在线| 国产视频在线免费观看| 成人高清免费| 国产一区二区精品久| 欧美激情中文字幕一区二区| 99久久精品国产片| 久久国产精品只做精品| 一本高清在线| 欧美大片一区| 成人在免费观看视频国产| 久草免费在线观看| 免费国产一级特黄aa大片在线| 国产高清在线精品一区a| 香蕉视频久久| 国产伦精品一区二区三区在线观看 | 精品视频一区二区三区免费| 精品国产三级a| 色综合久久久久综合体桃花网| 色综合久久天天综合观看| 天天色成人网| 国产伦精品一区三区视频| 99色视频在线观看| 亚洲精品久久玖玖玖玖| 精品久久久久久免费影院| 亚洲精品久久久中文字| 99热热久久| 色综合久久手机在线| 亚洲wwwwww| 日本伦理片网站| 国产成人啪精品视频免费软件| 久久精品欧美一区二区| 欧美激情伊人| 国产高清在线精品一区二区| 久久国产影院| 精品视频免费看| 国产福利免费观看| 国产成人欧美一区二区三区的| 久久国产一区二区| 国产a免费观看| a级毛片免费观看网站| 精品国产一区二区三区免费| 免费一级片在线| 国产一级生活片| 成人免费网站久久久| 97视频免费在线观看| 欧美一级视| a级精品九九九大片免费看| 欧美另类videosbestsex视频 | 国产不卡高清| 精品在线视频播放| 免费一级生活片| 日韩免费在线视频| 亚洲wwwwww| 国产原创视频在线| 午夜家庭影院| 99久久精品国产麻豆| 免费国产在线视频| 九九国产| 国产不卡在线观看视频| 超级乱淫伦动漫| 四虎久久影院| 亚飞与亚基在线观看| 欧美激情一区二区三区在线播放| 99色吧| 日韩专区第一页| 国产激情一区二区三区| 九九精品在线播放| 欧美a级片免费看| 成人免费福利片在线观看| 九九久久99| 欧美另类videosbestsex| 欧美α片无限看在线观看免费| 免费毛片播放| 精品在线观看国产| 精品久久久久久免费影院| 国产精品免费久久| 亚洲 国产精品 日韩| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久99中文字幕久久| 九九久久99| 国产视频一区在线| 国产激情一区二区三区| 你懂的日韩| 久久精品道一区二区三区| 精品久久久久久综合网| 一级毛片视频播放| 久久精品道一区二区三区| 九九精品在线播放| 国产极品白嫩美女在线观看看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 |