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 固定服务器角色成员或具有 ALTER TRACE 权限的用户才能指定 19 到 25 之间的严重级别。若要使用 19 到 25 之间的严重级别,必须选择 WITH LOG 选项。

注意,如果错误级别在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 固定服务器角色

成员或具有 ALTER TRACE 权限的用户才能指定 WITH LOG。

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

mysql raiserror_sql server数据库中raiserror函数的用法相关推荐

  1. mysql raiserror_sql server数据库中raiserror函数用法的详细介绍

    sql server数据库中raiserror函数的用法 server数据库中raiserror的作用就和asp.NET中的throw new Exception一样,用于抛出一个异常或错误.这个错误 ...

  2. sql server数据库中raiserror函数的用法1

    server数据库中raiserror的作用就和asp.net中的throw new Exception一样,用于抛出一个异常或错误.这个错误可以被程序捕捉到. raiserror的常用格式如下: r ...

  3. oracle数据库中 instr函数的用法

    oracle数据库中 instr函数的用法 一.instr函数的概念 在Oracle中可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符.在一个字符串中查找指定的字符,返回被查找到的 ...

  4. repeat mysql翻译_MySQL数据库中系统函数repeat有哪些功能呢?

    摘要: 下文讲述MySQL数据库中系统函数repeat的功能说明,如下所示: 系统函数repeat的功能: repeat函数的功能: 重复前面字符串指定次数 repeat语法: repeat(str, ...

  5. mysql中怎么用trunc_oracel数据库中trunc函数的用法

    trunc 函数可用于截取日期时间 用法:trunc(字段名,精度) 具体实例: 在表t_Engine_Process中,有一个字段名为sysdate,日期显示:2016/10/28 15:11:58 ...

  6. 秒懂SQL SERVERE 数据库中RAISERROR的基本用法

    基本用法 raiserror(msg,severity,state) 一.msg 错误信息. 二.severity 错误信息的级别,我们可以指定 0 到 18 之间的严重级别. 只有 sysadmin ...

  7. mysql raiserror_RAISERROR在SQL Server数据库中的用法

    raiserror  是由单词 raise error 组成 raise  增加; 提高; 提升 raiserror 的作用: raiserror 是用于抛出一个错误.[ 以下资料来源于sql ser ...

  8. MySQL的position值是什么_MySQL数据库中系统函数POSITION功能简介

    摘要: 下文讲述MySQL数据库中系统函数POSITION的功能说明,如下所示: 系统函数POSITION功能: 用于查找一个字符串在另一个字符串中第一次出现的位置 当无法在原始字符串中查找到子字符串 ...

  9. mysql查询加伪列_SQL Server数据库中伪列及伪列的含义详解

    SQL Server中的伪列 下午看QQ群有人在讨论(非聚集)索引的存储,说,对于聚集索引表,非聚集索引存储的是索引键值+聚集索引键值:对于非聚集索引表,索引存储的是索引键值+RowId,这应该是一个 ...

最新文章

  1. Linux执行df -h等操作卡住问题
  2. Emmet插件使用方法总结
  3. js校验文本框只能输入数字(包括小数)
  4. ubuntu下编译pjsip
  5. 100篇原创博文有感
  6. 22课时、19大主题,CS 231n进阶版课程视频来了
  7. 为什么合伙公司,一定要重视退出机制呢?
  8. 面试python说会为什么_Python面试必须要看的15个问题
  9. 拆机清灰重装系统数据恢复——心得汇总
  10. AI 全自动玩斗地主,靠谱吗?Douzero算法教程
  11. 卷积神经网络完整总结
  12. win7连接打印机0x0000011b错误的解决办法
  13. 颁奖 | 阿D给你发年终奖啦~
  14. 数据分析工程师_第02讲Pandas教程(上篇)
  15. 在StarRocks中建立ClickHouseJDBC外表
  16. 18719 填涂颜色
  17. 【深度学习】2-模型在测试集的准确率大于训练集
  18. fatal error: cusparse.h: No such file or directory compilation terminated. error: command ‘/usr/loca
  19. 本科毕业论文的引言怎么写?
  20. 企业战略 平台转型:不走寻常路

热门文章

  1. OrientDB恢复数据库
  2. 项目实训—基于AI的智能视频剪辑器(六)GIF片段合成视频
  3. bower到底是啥?
  4. 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?(PHP 递推,动态规划)
  5. 02,Python网络爬虫第二弹《http和https协议》
  6. 中国画的创作需要不似之似的创作理念
  7. c语言中阻止程序退出的函数,(转)C语言中Exit函数的使用
  8. unity代码更换ui图片_Unity UI图片的一种优化方式
  9. 计算机毕业设计Java沧州雄狮足球俱乐部管理系统(源码+系统+mysql数据库+lw文档
  10. 你觉得一个软件设计师要具备什么样的能力?