raiserror  是由单词 raise error 组成

raise  增加; 提高; 提升

raiserror 的作用: raiserror 是用于抛出一个错误。

其语法如下:

RAISERROR ( { msg_id | msg_str | @local_variable }

{ ,severity ,state }

[ ,argument [ ,...n ] ]

)

[ WITH option [ ,...n ] ]

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

msg_id:表示可以是一个sys.messages表中定义的消息代号;

使用 sp_addmessage 存储在 sys.messages 目录视图中的用户定义错误消息号。

用户定义错误消息的错误号应当大于 50000。

msg_str:表示也可以是一个用户定义消息,该错误消息最长可以有 2047 个字符;

(如果是常量,请使用N'xxxx',因为是nvarchar的)

当指定 msg_str 时,RAISERROR 将引发一个错误号为 5000 的错误消息。

@local_variable:表示也可以是按照 msg_str 方式的格式化字符串变量。

第二个参数:severity

用户定义的与该消息关联的严重级别。(这个很重要)

任何用户都可以指定 0 到 18 之间的严重级别。

[0,10]的闭区间内,不会跳到catch;

如果是[11,19],则跳到catch;

如果[20,无穷),则直接终止数据库连接;

第三个参数:state

如果在多个位置引发相同的用户定义错误,

则针对每个位置使用唯一的状态号有助于找到引发错误的代码段。

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

当state 值为 0 或大于 127 时会生成错误!

第四个参数:argument

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

第五个参数:option

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

LOG :在错误日志和应用程序日志中记录错误;

NOWAIT:将消息立即发送给客户端;

SETERROR:将 @@ERROR 值和 ERROR_NUMBER 值设置为 msg_id 或 50000;

来看一些具体的例子吧。

--示例1

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)

--示例2

--www.

RAISERROR (

N'This is message %s %d.', -- Message text,

10, -- Severity,

1, -- State,

N'number', -- First argument.

5 -- Second argument.

);

-- The message text returned is: This is message number 5.

GO

--示例3

RAISERROR (N'', -- Message text.

10, -- Severity,

1, -- State,

7, -- First argument used for width.

3, -- Second argument used for precision.

N'abcde'); -- Third argument supplies the string.

-- The message text returned is: >.

GO

--示例4

RAISERROR (N'', -- Message text.

10, -- Severity,

1, -- State,

N'abcde'); -- First argument supplies the string.

-- The message text returned is: >.

GO

--示例5

--A. 从 CATCH 块返回错误消息

以下代码示例显示如何在 TRY 块中使用 RAISERROR 使执行跳至关联的 CATCH 块中。

它还显示如何使用 RAISERROR 返回有关调用 CATCH 块的错误的信息。

BEGIN TRY

RAISERROR ('Error raised in TRY block.', -- Message text.

16, -- Severity.

1 -- State.

);

END TRY

BEGIN CATCH

DECLARE @ErrorMessage NVARCHAR(4000);

DECLARE @ErrorSeverity INT;

DECLARE @ErrorState INT;

SELECT

@ErrorMessage = ERROR_MESSAGE(),

@ErrorSeverity = ERROR_SEVERITY(),

@ErrorState = ERROR_STATE();

RAISERROR (@ErrorMessage, -- Message text.

@ErrorSeverity, -- Severity.

@ErrorState -- State.

);

END CATCH;

--示例6

--B. 在 sys.messages 中创建即席消息

以下示例显示如何引发 sys.messages 目录视图中存储的消息。

该消息通过 sp_addmessage 系统存储过程,以消息号50005添加到 sys.messages 目录视图中。

sp_addmessage @msgnum = 50005,

@severity = 10,

@msgtext = N'';

GO

RAISERROR (50005, -- Message id.

10, -- Severity,

1, -- State,

N'abcde'); -- First argument supplies the string.

-- The message text returned is: >.

GO

sp_dropmessage @msgnum = 50005;

GO

--示例7

--C. 使用局部变量提供消息文本

以下代码示例显示如何使用局部变量为 RAISERROR 语句提供消息文本。

sp_addmessage @msgnum = 50005,

@severity = 10,

@msgtext = N'';

GO

RAISERROR (50005, -- Message id.

10, -- Severity,

1, -- State,

N'abcde'); -- First argument supplies the string.

-- The message text returned is: >.

GO

sp_dropmessage @msgnum = 50005;

GO

mysql raiserror_sql server RAISERROR用法介绍相关推荐

  1. 什么是mysql的游标_MySQL游标概念是什么 MySQL游标概念与用法介绍

    本篇文章小编给大家分享一下MySQL游标概念与用法介绍,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看. 1.游标的概念(Cursor) 一条sql,对应N条资源,取出资源的接 ...

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

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

  3. mysql raiserror_sql server数据库中raiserror函数的用法

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

  4. mysql raiserror_SQL Server自定义异常的使用raiserror

    在使用SQL Server存储过程或者触发器时,通常会使用自定义异常来处理一些特殊逻辑.例如游标的销毁,事务的回滚.接下来将会详细的介绍SQL Server自定义异常的使用. 使用"rais ...

  5. php中使用mysql的视图_MYSQL中视图的用法介绍(代码示例)

    本篇文章给大家带来的内容是关于MYSQL中视图的用法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 1.什么是视图 执行一条SQL,将结果集保存在一张虚拟表中 (相关 ...

  6. sql raiserror_SQL Server PRINT和SQL Server RAISERROR语句

    sql raiserror This article explores the SQL Server PRINT statements, and its alternative SQL Server ...

  7. mysql 模糊查询用法_mysql进阶(六)模糊查询的四种用法介绍

    mysql中模糊查询的四种用法介绍 这篇文章主要介绍了mysql中模糊查询的四种用法,需要的朋友可以参考下. 下面介绍mysql中模糊查询的四种用法: 1 %: 表示任意0个或多个字符.可匹配任意类型 ...

  8. oracle的优化适用于mysql吗_性能优化之数据库优化,适用于Sqlite、Mysql、Oracle、Sql server,详细介绍了索引和事务及部分针对Sqlite的优化...

    本文为性能优化的第一篇--数据库性能优化,原理适用于大部分数据库包括Sqlite.Mysql.Oracle.Sql server,详细介绍了索引(优缺点.分类.场景.规则)和事务,最后介绍了部分单独针 ...

  9. [转载]MySQL exists的用法介绍

    原文摘自:http://www.cnblogs.com/glory-jzx/archive/2012/07/19/2599215.html MySQL exists的用法介绍 有一个查询如下: 1 S ...

最新文章

  1. 偷天换日,逼真的天空置换算法
  2. 很专业的Flash游戏
  3. Spring+CXF之集成
  4. LocalDB 静默安装
  5. sql的加减乘除运算_小白学sql(一)
  6. 岗位多多,招聘 23人 | 中国农业科学院深圳农业基因组研究所诚聘博士后和科研人员...
  7. FPGA加法器时分复用减少逻辑资源
  8. 计算机自动控制论文,电气自动化控制人工智能技术研究-人工智能论文-计算机论文.docx...
  9. 为什么我们需要域?MS Active Directory系列之一
  10. 如何用Python实现杨辉三角和心
  11. MySQL的timeout那点事
  12. 毕设题目:Matlab验证码识别
  13. Java如何进行Base64的编码(Encode)与解码(Decode)
  14. 10个SQL注入工具
  15. 2022年成都市市长质量奖申报、评选、表彰、监督管理等活动
  16. 【故障诊断分析】滚动轴承故障诊断系统含Matlab源码
  17. 自由软件江湖里的码头和规矩
  18. 论文阅读笔记—Exploring Visual Relationship for Image Captioning
  19. 在指定字符串后面插入字符串
  20. dpdk对虚拟化支持研究

热门文章

  1. 学计算机远程控制,怎样远程控制另一台电脑的方法步骤
  2. linux common comand
  3. THREE.GLTFLoader: Unknown extension “KHR_materials_pbrSpecularGlossiness“.
  4. NC | 中科院先进院戴磊组开发SEER-FISH成像技术解析微生物组空间结构
  5. Vue 单页应用 的 首屏优化
  6. [转载]EDID和TV OSD的使用说明
  7. 杰理AC692N系列增加编码器通过AD检测方式
  8. Unity填坑之粒子的ScaleMode
  9. Guitar Pro8许可证序列号是多少?
  10. 相关性学习在金融中的应用研究(金融中的应用研究)