sql中row的用法(sql server数据库中raiserror函数用法的详细介绍)
sql中row的用法
sql server数据库中raiserror函数用法的详细介绍sql server数据库中raiserror函数的用法
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
到此这篇关于sql server数据库中raiserror函数用法的详细介绍的文章就介绍到这了,更多相关sql server中raiserror函数用法内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- sqlserver怎么显示变量所占字节数(SQL Server中关于基数估计计算预估行数的一些方法探讨)
- sqlserver触发器修改当前字段(利用SQL Server触发器实现表的历史修改痕迹记录)
- sqlserver安装日志文件夹(SQL SERVER日志进行收缩的图文教程)
- 修改sqlserver数据库所有者
- sqlserver语句显示表字段(SQL Server查找表名或列名中包含空格的表和列实例代码)
- sqlserver数据库的对象有哪些(详解SQL Server数据库架构和对象、定义数据完整性)
- SqlServer类似正则表达式的字符处理问题(SqlServer类似正则表达式的字符处理问题)
- sqlserver分组查询(sql server如何利用开窗函数over进行分组统计)
- sqlserver字符串判断函数(解决sql server保存对象字符串转换成uniqueidentifier失败的问题)
- sqlserver中有几种锁定模式(SQL Server 开窗函数 Over代替游标的使用详解)
- sqlserver常用基本数据类型有哪些(浅述SQL Server的语句类别 数据库范式 系统数据库组成)
- sqlserver索引策略(SQLServer性能优化--间接实现函数索引或者Hash索引)
- sqlserver提供的内置函数(Sqlserver 自定义函数 Function使用介绍)
- sqlserver存储过程同步数据(SQL Server存储过程同时返回分页结果集和总数)
- centos系统mysql安装及连接教程(CentOS8安装SQLServer2019的过程)
- sqlserver仲裁状态(使用 SQL 服务器时,"评估期已过期"错误消息解决方法)
- 成都轨道交通19号线二期全线电通(成都轨道交通19号线二期全线电通)
- 19号线二期全线电通 轨道交通项目最新进展来了(19号线二期全线电通)
- 涉及3条地铁线路 成都这4座轨道交通站点有新名字了(涉及3条地铁线路)
- 来了 成都轨道交通5条线路刷新 进度条(成都轨道交通5条线路刷新)
- 一部手机两套系统 OPPO Find X3的正确打开方式你知道吗(一部手机两套系统)
- OPPO用户看过来 汇总几个春节实用技巧,轻松搞定多设备联动玩法(汇总几个春节实用技巧)
热门推荐
- python迭代函数(详解Python中的内建函数,可迭代对象,迭代器)
- python中jieba库怎么用(详解Python数据可视化编程 - 词云生成并保存jieba+WordCloud)
- idea 启动docker容器不重新打包(Docker遇到Intellij IDEA,Java开发提升了十倍生产力)
- 免费海外云主机有什么优势(国外云主机有什么优势?怎么选择?)
- mysql的日志怎么清除(MySQL删除了记录不生效的原因排查)
- 阿里云负载均衡搭建教程(阿里云主机中的云解析负载均衡相关设置)
- extjs table布局
- css可以控制网页背景图片吗(CSS实现网页背景图片自适应全屏的方法)
- kubernetes exec使用的接口(kubernetes YAML文件的使用)
- javascript 经典算法(JavaScript实现的七种排序算法总结推荐!)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9