设为首页 收藏本站
查看: 1061|回复: 0

[经验分享] sql server数据库中raiserror函数的用法

[复制链接]

尚未签到

发表于 2017-12-13 23:31:38 | 显示全部楼层 |阅读模式
  server数据库中raiserror的作用就和asp.NET中的throw new Exception一样,用于抛出一个异常或错误。这个错误可以被程序捕捉到。
  raiserror的常用格式如下:
  raiserror('错误的描述',错误的严重级别代码,错误的标识,错误的描述中的参数的值(这个可以是多个),一些其它参数),在官方上的格式描述如下:

  • RAISERROR ( { msg_id | msg_str | @local_variable }
  •     { ,severity ,state }
  •     [ ,argument [ ,...n ] ] )
  •     [ WITH option [ ,...n ] ]
  其中,[ ,argument [ ,...n ] ]与 [ WITH option [ ,...n ] 两项是可以不写的。
  分别解释一下各参数的用法:
  一、{ msg_id | msg_str | @local_variable }
  从这个参数中可以看出,这一项可能为三个值,
  1,sys.messages中的自定义错误信息的错误信息号,自定义错误信息可以使用sp_addmessage存储过程添加到sys.messages中,注意, 用户定义错误消息的错误号应当大于 50000。
  示例:raiserror(50001,16,1)
  2,一条直接的错误描述,示例:raiserror('这里是错误描述的示例',16,1)
  3,一个包含错误描述变量,示例:

  • declare @error_mes varchar(1000)
  • set @error_mes='这里是错误描述的示例'
  • raiserror(@error_mes,16,1)
  二、severity

  这个参数为用户定义的该错误信息的级别,我们可以指定 0 到 18 之间的严重级别。只有 sysadmin 固定服务器角色成员或具有>  注意,如果错误级别在20~25之间,那么数据库会认为这个错误是致命,那么数据库会将该错误记录到错误日志和应用程序日志后终止数据库的连接。任何小于 0 的严重级别被认为等于0。大于 25 的严重级别被认为等于25。
  三、state
  这个参数是可以是1~127之间任意整数,可以用来标识错误的发生位置,如果一段代码的多个位置都会发生同样的错误,那么就可以将这个参数设置为不同的值,用来标识是那个位
  置发生错误了。
  四、[ ,argument [ ,...n ] ]
  如果参数{ msg_id | msg_str | @local_variable }中包含了一些代替符,那么这个参数就是代替符的具体的值,这个和asp.Net中的string.Format用法是一样的。示例如下:

  • declare @error_mes varchar(1000)
  • set @error_mes='这里是用户%s引发的错误描述'
  • raiserror(@error_mes,16,1,'张三')
  也可以是这样,可能适用性更广些。

  • declare @error_mes varchar(1000)
  • declare @error_obj varchar(1000)
  • select @error_obj=name from table_users where……
  • set @error_mes='这里是用户%s引发的错误描述'
  • raiserror(@error_mes,16,1,@error_obj)
  上面代码中的%s,代表它要替代是一个字符串,如果我们把示例写成下面这样就会报错了:

  • declare @error_mes varchar(1000)
  • set @error_mes='这里是用户%s引发的错误描述'
  • raiserror(@error_mes,16,1,1)
  因为1不是一个字符串,如果要替代是一个整数,就需要使用%i或者%d了。所有的对应关系如下:
  1,%d或%i代表有符号整数
  2,%u代表无符号整数
  3,%o代表无符号八进制数
  4,%s代表字符串
  5,%x或%X代表 无符号十六进制数
  五、[ WITH option [ ,...n ] ]
  该参数为错误的自定义选项,可以是下面三个值中的一个:
  1,LOG--在 Microsoft SQL Server 数据库引擎 实例的错误日志和应用程序日志中记录错误。记录到错误日志的错误目前被限定为最多 440 字节。只有 sysadmin 固定服务器角色

  成员或具有>  2,NOWAIT--将消息立即发送给客户端。
  3,SETERROR--将 @@ERROR 值和 ERROR_NUMBER 值设置为 msg_id 或 50000,不用考虑严重级别。
  我们还可以在Begin catch中使用raiserror。示例如下:

  • begin try
  • raiserror('这是一个错误',16,1) //注意,只有severity级别在11~19之间,控制才会跳转到catch块中。
  • end try
  • begin catch
  • declare @error_message varchar(1000)
  • set @error_message=error_message()
  • raiserror(@error_message,16,1)
  • return
  • end catch
  http://blog.csdn.net/qq_25627143/article/details/50814637

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-423846-1-1.html 上篇帖子: 关于sql server 2005存储过程的写法 下篇帖子: SQL Server连接不上本地服务器
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表