佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > SQL Server自定義異常raiserror使用示例

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

熱門標(biāo)簽:百度競(jìng)價(jià)排名 呼叫中心市場(chǎng)需求 地方門戶網(wǎng)站 AI電銷 Linux服務(wù)器 網(wǎng)站排名優(yōu)化 服務(wù)外包 鐵路電話系統(tǒng)

在使用SQL Server存儲(chǔ)過程或者觸發(fā)器時(shí),通常會(huì)使用自定義異常來處理一些特殊邏輯。例如游標(biāo)的銷毀,事務(wù)的回滾。接下來將會(huì)詳細(xì)的介紹SQL Server自定義異常的使用。

使用“raiserror”來拋出自定義異常。如下代碼:在存儲(chǔ)過程中,拋出自定義異常,然后在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; -- 因?yàn)楸怀龜?shù)為0,所以這里將會(huì)拋出一個(gè)系統(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)識(shí),且這個(gè)值會(huì)被賦值給SQLServer的系統(tǒng)變量@@Error。自定義異常的Message Id建議使用50000以后的,因?yàn)?0000以內(nèi)的會(huì)被系統(tǒng)異常占用。
(2). Severity : 異常的級(jí)別。 可輸入1—19的數(shù)值。1—10之間不會(huì)被catch捕獲。19以后是非常嚴(yán)重的級(jí)別。
(3). State : 如果輸入負(fù)值或大于255 的值會(huì)生成錯(cuò)誤,產(chǎn)生錯(cuò)誤則會(huì)中斷數(shù)據(jù)庫(kù)的連接

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

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


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

標(biāo)簽:銅川 崇左 仙桃 湘潭 黃山 衡水 蘭州 湖南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server自定義異常raiserror使用示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    中江县| 丰城市| 莲花县| 玉门市| 嘉峪关市| 合阳县| 佛坪县| 通辽市| 府谷县| 澄江县| 洪雅县| 自贡市| 浦北县| 凤庆县| 梅河口市| 都江堰市| 博野县| 乐业县| 清水县| 怀柔区| 南平市| 阿拉尔市| 印江| 东乡县| 武定县| 卓资县| 临江市| 闵行区| 武宁县| 尚义县| 静宁县| 牟定县| 富锦市| 大宁县| 宁夏| 玛沁县| 霸州市| 桐梓县| 锦州市| 西吉县| 新巴尔虎左旗|