捕捉异常:try---catch
SQL提供了和编程语言类似的try-catch机制,帮助存储过程更加健壮,不至于遇到任何错误就终结存储过程。在try的语句块中遇到异常后,会暂停执行try的SQL语句,并跳转到最近的catch代码块中继续执行。
语法框架
Begin try
Begin
[需要执行的SQL语句]
End
End try
Begin catch
Begin
[在上一个begin try和end try中一旦产生异常,就会停止执行
剩下的语句,并跳转到begin catch和end catch的语句中继续
执行]
End
End catch
制造异常
以SQL server为例,它提供了raiserror()函数用于抛出异常。其实有很多编程语言都提供了相似的异常捕获机制,因此这种机制对于有编程基础的小伙伴来说会非常熟悉。
raiserror()的语法结构
1 RAISERROR ( { msg_id | msg_str | @local_variable }
2 { ,severity ,state }
3 [ ,argument [ ,...n ] ]
4 )
5 [ WITH option [ ,...n ] ]
这个函数中各个参数的意义可以参考这一篇文章,我在此不做太多赘述:
这五个参数中的后两个可以不填,因此可以将这个函数简化成一下形式:
1 RAISERROR (msg_str,severity,state)
2 /*
3 msg_str:用户自定义的错误消息
4 Severity:错误级别。任何用户都可以指定 0 到 18 之间的严重级别。[0,10]的闭区间内,不会跳到catch;如果是[11,19],则跳到catch;如果[20,无穷),则直接终止数据库连接
5 State:介于 1 至 127 之间的任意整数。(state 默认值为1)当state 值为 0 或大于 127 时会生成错误!
6 */
raiserror()的简单用法
在刚接触编程时,我对这种人为产生异常的行为非常困惑——我们写SQL语句都是尽量避免报错,为什么还要主动生成错误?
在实际使用中,这个函数常常配合判断语句用于定位错误位置,区分错误类型。
Begin try
Begin
If (条件一)
raiserror(错误1,11,1)
If (条件二)
raiserror(错误2,11,2)
If (条件三)
raiserror(错误3,11,3)
End
End try
Begin catch
Begin
[遇到异常后执行的语句]
End
End catch
常用的和异常相关的系统函数
通过这些函数可以帮助我们更好的定位和判断错误信息
ERROR_NUMBER() --返回错误号。
ERROR_SEVERITY() --返回严重性。
ERROR_STATE() --返回错误状态号。
ERROR_PROCEDURE() --返回出现错误的存储过程或 触发器的名称。
ERROR_LINE() --返回导致错误的例程中的行 号。
ERROR_MESSAGE() --返回错误消息的完整文本。