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

主頁 > 知識庫 > SQL Server 中 RAISERROR 的用法詳細介紹

SQL Server 中 RAISERROR 的用法詳細介紹

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

 SQL Server 中 RAISERROR 的用法

raiserror 的作用: raiserror 是用于拋出一個錯誤。[ 以下資料來源于sql server 2005的幫助 ]

其語法如下:

RAISERROR ( { msg_id | msg_str | @local_variable }    
      { ,severity ,state }    
      [ ,argument [ ,...n ] ] 
     )    
  [ WITH option [ ,...n ] ]

簡要說明一下:

  第一個參數(shù):{ msg_id | msg_str | @local_variable }

      msg_id:表示可以是一個sys.messages表中定義的消息代號;
              使用 sp_addmessage 存儲在 sys.messages 目錄視圖中的用戶定義錯誤消息號。
              用戶定義錯誤消息的錯誤號應當大于 50000。

     msg_str:表示也可以是一個用戶定義消息,該錯誤消息最長可以有 2047 個字符;
             (如果是常量,請使用N'xxxx',因為是nvarchar的)
              當指定 msg_str 時,RAISERROR 將引發(fā)一個錯誤號為 5000 的錯誤消息。

     @local_variable:表示也可以是按照 msg_str 方式的格式化字符串變量。           

第二個參數(shù):severity

           用戶定義的與該消息關聯(lián)的嚴重級別。(這個很重要)
            任何用戶都可以指定 0 到 18 之間的嚴重級別。
            [0,10]的閉區(qū)間內(nèi),不會跳到catch;
            如果是[11,19],則跳到catch;
            如果[20,無窮),則直接終止數(shù)據(jù)庫連接;

第三個參數(shù):state

            如果在多個位置引發(fā)相同的用戶定義錯誤,
            則針對每個位置使用唯一的狀態(tài)號有助于找到引發(fā)錯誤的代碼段。
         
            介于 1 至 127 之間的任意整數(shù)。(state 默認值為1)
            當state 值為 0 或大于 127 時會生成錯誤!

第四個參數(shù):argument

            用于代替 msg_str 或?qū)?msg_id 的消息中的定義的變量的參數(shù)。

第五個參數(shù):option

            錯誤的自定義選項,可以是下表中的任一值:
            LOG :在錯誤日志和應用程序日志中記錄錯誤;
            NOWAIT:將消息立即發(fā)送給客戶端;
            SETERROR:將 @@ERROR 值和 ERROR_NUMBER 值設置為 msg_id 或 50000;

[SQL]代碼示例

--示例1

DECLARE @raiseErrorCode nvarchar(50)
SET @raiseErrorCode = CONVERT(nvarchar(50), YOUR UNIQUEIDENTIFIER KEY)
RAISERROR('%s INVALID ID. There is no record in table',16,1, @raiseErrorCode)
 

--示例2

RAISERROR (
       N'This is message %s %d.', -- Message text,
       10,            -- Severity,
       1,             -- State,
       N'number',         -- First argument.
       5             -- Second argument.
     ); 
-- The message text returned is: This is message number 5.
GO

--示例3

RAISERROR (N'%*.*s>>', -- Message text.
      10,      -- Severity,
      1,      -- State,
      7,      -- First argument used for width.
      3,      -- Second argument used for precision.
      N'abcde');  -- Third argument supplies the string.
-- The message text returned is:   abc>>.
GO

--示例4

RAISERROR (N'%7.3s>>', -- Message text.
      10,      -- Severity,
      1,      -- State,
      N'abcde');  -- First argument supplies the string.
-- The message text returned is:   abc>>.
GO

--示例5   

--A. 從 CATCH 塊返回錯誤消息

以下代碼示例顯示如何在 TRY 塊中使用 RAISERROR 使執(zhí)行跳至關聯(lián)的 CATCH 塊中。
它還顯示如何使用 RAISERROR 返回有關調(diào)用 CATCH 塊的錯誤的信息。


BEGIN TRY
  RAISERROR ('Error raised in TRY block.', -- Message text.
        16, -- Severity.
        1 -- State.
        );
END TRY
BEGIN CATCH
  DECLARE @ErrorMessage NVARCHAR(4000);
  DECLARE @ErrorSeverity INT;
  DECLARE @ErrorState INT;

  SELECT 
    @ErrorMessage = ERROR_MESSAGE(),
    @ErrorSeverity = ERROR_SEVERITY(),
    @ErrorState = ERROR_STATE();

  RAISERROR (@ErrorMessage, -- Message text.
        @ErrorSeverity, -- Severity.
        @ErrorState   -- State.
        );
END CATCH;

--示例6

--B. 在 sys.messages 中創(chuàng)建即席消息
以下示例顯示如何引發(fā) sys.messages 目錄視圖中存儲的消息。
該消息通過 sp_addmessage 系統(tǒng)存儲過程,以消息號50005添加到 sys.messages 目錄視圖中。


sp_addmessage @msgnum = 50005,
        @severity = 10,
        @msgtext = N'%7.3s>>';
GO

RAISERROR (50005, -- Message id.
      10,  -- Severity,
      1,   -- State,
      N'abcde'); -- First argument supplies the string.
-- The message text returned is:   abc>>.
GO

sp_dropmessage @msgnum = 50005;
GO

--示例7

--C. 使用局部變量提供消息文本
以下代碼示例顯示如何使用局部變量為 RAISERROR 語句提供消息文本。

sp_addmessage @msgnum = 50005,
       @severity = 10,
       @msgtext = N'%7.3s>>';
GO

RAISERROR (50005, -- Message id.
      10,  -- Severity,
      1,   -- State,
      N'abcde'); -- First argument supplies the string.
-- The message text returned is:   abc>>.
GO

sp_dropmessage @msgnum = 50005;
GO

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

您可能感興趣的文章:
  • SQL Server自定義異常raiserror使用示例
  • sql server數(shù)據(jù)庫中raiserror函數(shù)用法的詳細介紹

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

巨人網(wǎng)絡通訊聲明:本文標題《SQL Server 中 RAISERROR 的用法詳細介紹》,本文關鍵詞  SQL,Server,中,RAISERROR,的,用法,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 中 RAISERROR 的用法詳細介紹》相關的同類信息!
  • 本頁收集關于SQL Server 中 RAISERROR 的用法詳細介紹的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 尤溪县| 库车县| 石嘴山市| 达孜县| 日喀则市| 青阳县| 内乡县| 普兰县| 庆阳市| 瓦房店市| 赤峰市| 嘉荫县| 巧家县| 潼关县| 二连浩特市| 红安县| 林芝县| 沿河| 伊宁县| 长葛市| 贵港市| 临西县| 和林格尔县| 墨脱县| 荣成市| 遵义县| 马鞍山市| 扬州市| 庄浪县| 青州市| 巧家县| 绥芬河市| 乌海市| 霍林郭勒市| 子洲县| 昂仁县| 景德镇市| 衡南县| 新晃| 阿瓦提县| 沛县|