婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

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

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

一、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中監測錯誤,只能通過監測全局遍歷 @@ERROR.由于@@ERROR會被下一個數據庫操作所覆蓋. 所以在每次操作完后必須立即監測.

二、SQL SERVER 2005中異常處理

TRY...CATCH是SQL Server 2005提供的更具有可讀性的語法.每個開發人員都熟悉這種寫法.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.獲得錯誤信息的函數表:

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

函數 描述

ERROR_NUMBER() 返回導致運行 CATCH 塊的錯誤消息的錯誤號。
ERROR_SEVERITY() 返回導致 CATCH 塊運行的錯誤消息的嚴重級別
ERROR_STATE() 返回導致 CATCH 塊運行的錯誤消息的狀態號
ERROR_PROCEDURE() 返回出現錯誤的存儲過程名稱
ERROR_LINE() 返回發生錯誤的行號
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

三、實例講解

創建錯誤日志表:

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

創建錯誤日志記錄存儲過程:

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數據庫備份時出現“操作系統錯誤5(拒絕訪問)。BACKUP DATABASE 正在異常終止。”錯誤的解決辦法
  • SQL Server自定義異常raiserror使用示例
  • SQLServer 連接異常與解決方法小結
  • SQLserver2000 企業版 出現"進程51發生了嚴重的異常"錯誤的處理方法
  • SqlServer異常處理常用步驟
  • SQL Server異常代碼處理的深入講解

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

巨人網絡通訊聲明:本文標題《SQL Server 2005 中使用 Try Catch 處理異常》,本文關鍵詞  SQL,Server,2005,中,使用,Try,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 2005 中使用 Try Catch 處理異常》相關的同類信息!
  • 本頁收集關于SQL Server 2005 中使用 Try Catch 處理異常的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩精品高清| 久久日韩精品一区二区五区| 九九九久久久精品| 国产精品看片你懂得| 91精品国产综合久久婷婷香蕉 | 午夜精品福利一区二区蜜股av| 久久影院午夜论| 欧美性大战xxxxx久久久| 国产精品资源站在线| 天天综合天天综合色| 亚洲综合一二区| 国产日韩欧美一区二区三区综合| 欧美一区二区在线免费观看| 色婷婷激情综合| av在线不卡免费看| 成人午夜免费电影| 大陆成人av片| 成人激情小说网站| 亚洲制服丝袜在线| 樱花草国产18久久久久| 一区二区三区四区五区视频在线观看| 亚洲国产经典视频| 国产亚洲午夜高清国产拍精品| 欧美一二三区在线观看| 日韩写真欧美这视频| 欧美色综合天天久久综合精品| av资源站一区| 日本福利一区二区| 在线免费精品视频| 欧美视频在线观看一区二区| 欧美日韩亚洲综合在线| 91精品国产一区二区三区蜜臀| 欧美日韩精品欧美日韩精品一| 欧美日韩免费一区二区三区 | 欧美日韩成人综合在线一区二区| 日本国产一区二区| 欧美色图天堂网| 日韩亚洲欧美一区二区三区| 91久久精品一区二区| 欧美视频第二页| 欧美成人伊人久久综合网| 91精品国产91久久综合桃花| 欧美xxxxx裸体时装秀| 国产午夜亚洲精品理论片色戒| 久久精品夜夜夜夜久久| 国产精品网站导航| 一区二区久久久久久| 亚洲va欧美va人人爽| 狠狠色丁香婷婷综合久久片| 成人美女视频在线看| 欧日韩精品视频| 久久丝袜美腿综合| 亚洲午夜视频在线观看| 国模套图日韩精品一区二区| 99在线精品一区二区三区| 91成人看片片| 久久夜色精品国产噜噜av| 亚洲欧洲精品一区二区三区| 午夜国产精品一区| 国产99久久精品| 日日骚欧美日韩| 亚洲chinese男男1069| 91免费观看在线| 国产精品久久久久影视| 国产麻豆精品在线| 日韩美女视频在线| 美女在线视频一区| 91精品久久久久久久久99蜜臂| 亚洲一区二区三区四区在线免费观看 | 亚洲激情欧美激情| 99久久精品国产导航| 国产欧美日韩不卡| 国产成人午夜视频| 国产午夜精品久久久久久免费视| 久久精品国产一区二区三区免费看| 3d成人h动漫网站入口| 亚洲成人在线观看视频| 欧美午夜精品久久久久久孕妇| 亚洲免费在线视频一区 二区| 99精品1区2区| 一区二区三区在线看| 欧洲色大大久久| 亚洲成人av免费| 9191国产精品| 蜜桃av一区二区在线观看| 日韩欧美国产高清| 久久av中文字幕片| 中文字幕 久热精品 视频在线 | 成人污视频在线观看| 亚洲欧美在线视频观看| 日本韩国欧美在线| 日本欧美久久久久免费播放网| 日韩三级精品电影久久久| 国产一区二区三区最好精华液| 国产日产亚洲精品系列| 99国产精品国产精品久久| 亚洲a一区二区| 久久在线观看免费| 日本伦理一区二区| 蜜桃av一区二区在线观看| 国产日韩欧美一区二区三区乱码| fc2成人免费人成在线观看播放| 亚洲免费观看高清| 日韩精品一区二| 成人av在线观| 日本不卡在线视频| 中文字幕一区二区视频| 欧美日韩免费一区二区三区视频| 韩国女主播成人在线观看| 亚洲欧美韩国综合色| 日韩欧美电影在线| 色综合天天视频在线观看| 久久99精品国产麻豆婷婷| 一区在线播放视频| 欧美精品一区二区三区在线| 91欧美激情一区二区三区成人| 日本午夜一本久久久综合| 国产精品不卡一区| 欧美mv和日韩mv的网站| 欧美亚洲综合在线| 国产ts人妖一区二区| 日本中文字幕不卡| 亚洲午夜久久久| 粉嫩嫩av羞羞动漫久久久| 亚洲婷婷综合久久一本伊一区| 日韩视频中午一区| 色香蕉成人二区免费| 成人91在线观看| 极品少妇一区二区三区精品视频| 亚洲在线观看免费| 国产精品理论在线观看| 精品久久人人做人人爰| 欧美猛男男办公室激情| av电影在线不卡| 成人午夜激情影院| 国产成人av电影在线| 久久99精品国产麻豆婷婷| 美国十次了思思久久精品导航| 日韩国产成人精品| 日韩精品视频网| 五月天激情综合网| 亚洲国产日产av| 亚洲一区在线视频| 亚洲图片自拍偷拍| 亚洲一区二区三区四区的| 樱花草国产18久久久久| 亚洲欧美激情在线| 亚洲柠檬福利资源导航| 国产精品女主播在线观看| 国产精品久久久久久久久快鸭 | 亚洲免费观看在线观看| 国产精品久久久99| 最新日韩在线视频| 亚洲日本在线观看| 亚洲韩国精品一区| 日韩综合在线视频| 久久国产精品色| 国产美女av一区二区三区| 懂色av一区二区夜夜嗨| 91看片淫黄大片一级| 在线欧美日韩国产| 欧美久久久一区| 日韩欧美中文一区二区| 精品国产乱码久久久久久免费 | 国产麻豆午夜三级精品| 国产精品综合一区二区| av资源网一区| 欧美日韩久久一区| 欧美成人一区二区| 一区二区中文视频| 亚洲成av人综合在线观看| 捆绑变态av一区二区三区| 丁香网亚洲国际| 欧美三级电影在线看| 精品国产网站在线观看| 国产精品久久久久久久久快鸭 | 亚洲欧洲成人av每日更新| 亚洲午夜久久久久| 久久99久久99小草精品免视看| 成人综合婷婷国产精品久久免费| 99re66热这里只有精品3直播 | 欧美亚洲日本国产| 精品久久久网站| 成人免费视频在线观看| 老司机免费视频一区二区| 成人av免费观看| 日韩视频永久免费| 国产精品传媒入口麻豆| 免费在线观看视频一区| 色综合久久天天综合网| 精品1区2区在线观看| 亚洲精品成人天堂一二三| 国产精品小仙女| 制服丝袜亚洲精品中文字幕| 国产精品国产三级国产aⅴ入口 | 色婷婷国产精品久久包臀| 精品处破学生在线二十三| 亚洲国产aⅴ天堂久久| 成人综合在线网站| 精品国产伦一区二区三区观看体验|