濮阳杆衣贸易有限公司

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

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

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

在使用SQL Server存儲過程或者觸發(fā)器時,通常會使用自定義異常來處理一些特殊邏輯。例如游標(biāo)的銷毀,事務(wù)的回滾。接下來將會詳細(xì)的介紹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; -- 因為被除數(shù)為0,所以這里將會拋出一個系統(tǒng)的異常
  end
  else begin
   set @j = @i;
   set @outstr = 'customer exception';
   -- 拋出自定義的異常,在最后的catch塊中統(tǒng)一處理異常
   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參數(shù)說明:

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

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

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


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

標(biāo)簽:石家莊 咸寧 南昌 珠海 北海 東營 煙臺 晉中

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server自定義異常raiserror使用示例》,本文關(guān)鍵詞  SQL,Server,自定義,異常,raiserror,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server自定義異常raiserror使用示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server自定義異常raiserror使用示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宝丰县| 盈江县| 丹巴县| 五常市| 象山县| 灌云县| 霍林郭勒市| 鹤壁市| 密山市| 宾川县| 阿拉善左旗| 讷河市| 宣恩县| 大荔县| 介休市| 洛隆县| 商都县| 柯坪县| 勐海县| 休宁县| 邵阳市| 大竹县| 长海县| 高阳县| 凤凰县| 阿图什市| 罗定市| 十堰市| 文登市| 连云港市| 阆中市| 郁南县| 永安市| 桃园市| 奉节县| 张家川| 辰溪县| 辉南县| 虎林市| 高青县| 巴青县|