好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SQL Server自定義異常raiserror使用示例

SQL Server自定義異常raiserror使用示例

熱門標簽:地圖標注一個圓圈怎么用 如何在地圖標注自己店鋪 洛陽外呼系統平臺 廣州人工電銷機器人費用 400外呼系統合法 怎樣把地圖標注導入公司地址 真人語音電銷機器人 電銷機器人被曝光 寧波人工外呼系統有效果嗎

在使用SQL Server存儲過程或者觸發器時,通常會使用自定義異常來處理一些特殊邏輯。例如游標的銷毀,事務的回滾。接下來將會詳細的介紹SQL Server自定義異常的使用。

使用“raiserror”來拋出自定義異常。如下代碼:在存儲過程中,拋出自定義異常,然后在catch塊中捕獲自定義異常。

IF EXISTS (SELECT * FROM SYSOBJECTS WHERE name='my_sp_test' AND TYPE='P') BEGIN
  DROP PROCEDURE my_sp_test;
END;
GO
create procedure my_sp_test @i int, @outstr varchar(100) out as
begin try
  declare @j int;
  if @i10 begin
   set @outstr = 'system exception.';
   set @j = 10/0; -- 因為被除數為0,所以這里將會拋出一個系統的異常
  end
  else begin
   set @j = @i;
   set @outstr = 'customer exception';
   -- 拋出自定義的異常,在最后的catch塊中統一處理異常
   RAISERROR (66666, -- Message id.
      16, -- Severity,
      1 -- State,
      ) ;  
  end;
end try
begin catch 
  if @@ERROR=66666 begin -- 通過@@ERROR的值來判斷是否是自定義的異常
    set @outstr = @outstr + '---------------- customer exception';
  end;
  return;
end catch;
go
 


如上代碼,raiserror參數說明:

(1). Message id : 異常的唯一標識,且這個值會被賦值給SQLServer的系統變量@@Error。自定義異常的Message Id建議使用50000以后的,因為50000以內的會被系統異常占用。
(2). Severity : 異常的級別。 可輸入1—19的數值。1—10之間不會被catch捕獲。19以后是非常嚴重的級別。
(3). State : 如果輸入負值或大于255 的值會生成錯誤,產生錯誤則會中斷數據庫的連接

執行該存儲過程,看看自定義異常是否成功捕獲:

DECLARE @OUTSTR11 VARCHAR(100);
exec dbo.my_sp_test 12,@OUTSTR11 out
print @OUTSTR11;


您可能感興趣的文章:
  • SQL Server出現System.OutOfMemoryException異常的解決方法
  • 解決SQL SERVER數據庫備份時出現“操作系統錯誤5(拒絕訪問)。BACKUP DATABASE 正在異常終止?!卞e誤的解決辦法
  • SQLServer 連接異常與解決方法小結
  • SQLserver2000 企業版 出現"進程51發生了嚴重的異常"錯誤的處理方法
  • SQL Server 2005 中使用 Try Catch 處理異常
  • SqlServer異常處理常用步驟
  • SQL Server異常代碼處理的深入講解

標簽:石家莊 咸寧 南昌 珠海 北海 東營 煙臺 晉中

巨人網絡通訊聲明:本文標題《SQL Server自定義異常raiserror使用示例》,本文關鍵詞  SQL,Server,自定義,異常,raiserror,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server自定義異常raiserror使用示例》相關的同類信息!
  • 本頁收集關于SQL Server自定義異常raiserror使用示例的相關信息資訊供網民參考!
  • 推薦文章