SQL Server中raiserror的介绍



一、raiserror语法



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



参数说明


第一个参数:{ msg_id | msg_str | @local_variable }


msg_id:消息代号,用户定义错误消息的错误号应当大于 50000。
msg_str:用户定义的错误消息,该错误消息最长可以有 2047 个字符;当指定 msg_str 时,RAISERROR 将引发一个错误号为 5000 的错误消息。


@local_variable:按照 msg_str 方式的格式化字符串变量。


 


第二个参数:severity


用户定义的与该消息关联的严重级别。任何用户都可以指定 0 到 18 之间的严重级别。
 


1、[0,10]的闭区间内,不会跳到catch;
2、如果是[11,19],则跳到catch;
3、如果[20,无穷),则直接终止数据库连接;
 


第三个参数:state


1、如果在多个位置引发相同的用户定义错误,则针对每个位置使用唯一的状态号有助于找到引发错误的代码段。


2、其值为 介于 1 至 127 之间的任意整数。(state 默认值为1)
 


第四个参数:argument


用于代替 msg_str 或对应于 msg_id 的消息中的定义的变量的参数。
 


第五个参数:option


错误的自定义选项,可以是下表中的任一值:


LOG :在错误日志和应用程序日志中记录错误;
NOWAIT:将消息立即发送给客户端;
SETERROR:将 @@ERROR 值和 ERROR_NUMBER 值设置为 msg_id 或 50000



二、SQL Server中raiserror实例


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)



文章转载自:   SQL Server中raiserror   http://www.studyofnet.com/news/829.html


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值