国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQL Server 中 RAISERROR 的用法詳細(xì)介紹

2020-10-30 19:05:16
字體:
供稿:網(wǎng)友

 SQL Server 中 RAISERROR 的用法

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

其語法如下:

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

簡要說明一下:

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

      msg_id:表示可以是一個(gè)sys.messages表中定義的消息代號;
              使用 sp_addmessage 存儲在 sys.messages 目錄視圖中的用戶定義錯(cuò)誤消息號。
              用戶定義錯(cuò)誤消息的錯(cuò)誤號應(yīng)當(dāng)大于 50000。

     msg_str:表示也可以是一個(gè)用戶定義消息,該錯(cuò)誤消息最長可以有 2047 個(gè)字符;
             (如果是常量,請使用N'xxxx',因?yàn)槭莕varchar的)
              當(dāng)指定 msg_str 時(shí),RAISERROR 將引發(fā)一個(gè)錯(cuò)誤號為 5000 的錯(cuò)誤消息。

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

第二個(gè)參數(shù):severity

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

第三個(gè)參數(shù):state

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

第四個(gè)參數(shù):argument

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

第五個(gè)參數(shù):option

            錯(cuò)誤的自定義選項(xiàng),可以是下表中的任一值:
            LOG :在錯(cuò)誤日志和應(yīng)用程序日志中記錄錯(cuò)誤;
            NOWAIT:將消息立即發(fā)送給客戶端;
            SETERROR:將 @@ERROR 值和 ERROR_NUMBER 值設(shè)置為 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 塊返回錯(cuò)誤消息

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

BEGIN TRY  RAISERROR ('Error raised in TRY block.', -- Message text.        16, -- Severity.        1 -- State.        );END TRYBEGIN 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>>';GORAISERROR (50005, -- Message id.      10,  -- Severity,      1,   -- State,      N'abcde'); -- First argument supplies the string.-- The message text returned is: <<  abc>>.GOsp_dropmessage @msgnum = 50005;GO

--示例7

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

sp_addmessage @msgnum = 50005,       @severity = 10,       @msgtext = N'<<%7.3s>>';GORAISERROR (50005, -- Message id.      10,  -- Severity,      1,   -- State,      N'abcde'); -- First argument supplies the string.-- The message text returned is: <<  abc>>.GOsp_dropmessage @msgnum = 50005;GO

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 岳池县| 惠水县| 绥德县| 双辽市| 塘沽区| 桦川县| 阿拉善左旗| 苗栗市| 兖州市| 博乐市| 宁晋县| 通榆县| 赤峰市| 卢湾区| 磐石市| 通州市| 万州区| 新乡县| 沧州市| 墨脱县| 东宁县| 浦江县| 确山县| 西昌市| 宁陵县| 江川县| 太原市| 通榆县| 邻水| 巩义市| 五常市| 乌鲁木齐县| 当涂县| 乌鲁木齐县| 雅安市| 衢州市| 邵阳市| 聂拉木县| 吐鲁番市| 海安县| 吉木萨尔县|