raiserror 在 java_Sql 的 RAISERROR用法

raiserror 在 java_Sql 的 RAISERROR用法http www yesky com imagesnew software tsql ts ra rz 5ooi htmRAISERROR 返回用户定义的错误信息并设系统标志 记录发生错误 通过使用 RAISERROR 语句 客户端可以从 sysmessages 表中检索条目 或者使用用户指定的严重度和状态信息动态地生成一条消息 这条消息在定义后就作为服务器错误信息返回给客户端 语法 RAISER

http://www.yesky.com/imagesnew/software/tsql/ts_ra-rz_5ooi.htm

RAISERROR

返回用户定义的错误信息并设系统标志,记录发生错误。通过使用 RAISERROR 语句,客户端可以从 sysmessages 表中检索条目,或者使用用户指定的严重度和状态信息动态地生成一条消息。这条消息在定义后就作为服务器错误信息返回给客户端。

语法

RAISERROR ({ msg_id | msg_str} { , severity, state}

[ , argument[ ,…n] ] )

[ WITH option[ ,…n] ]

参数

msg_id

存储于 sysmessages 表中的用户定义的错误信息。用户定义错误信息的错误号应大于 50,000。由特殊消息产生的错误是第 50,000 号。

msg_str

是一条特殊消息,其格式与 C 语言中使用的 PRINTF 格式样式相似。此错误信息最多可包含 400

个字符。如果该信息包含的字符超过 400 个,则只能显示前 397 个并将添加一个省略号以表示该信息已被截断。所有特定消息的标准消息 ID 是

14,000。

msg_str支持下面的格式:

% [[flag] [width] [precision] [{h | l}]] type

可在 msg_str中使用的参数包括:

flag

用于确定用户定义的错误信息的间距和对齐的代码。

代码前缀或对齐描述

-(减)

左对齐

在给定字段宽度内左对齐结果。

+(加)

+(加)或 -(减)前缀

如果输出值为带符号类型,则在输出值的前面加上加号(+)或减号(-)。

0(零)

零填充

如果宽度的前面有 0,则添加零直到满足最小宽度。若出现 0 和 -,将忽略 0。若使用整型格式(i, u, x, X, o, d)指定 0,则忽略 0。

#(数字)

对 x 或 X 的十六进制类型使用 0x 前缀

当使用 o、x 或 X 格式时,# 标志在任何非零值的前面分别加上 0、0x 或 0X。当 d、i 或 u 的前面有 # 标记时,将忽略该标记。

‘ ‘(空格)

空格填充

如果输出值带符号且为正,则在该值前加空格。如果包含在加号(+)标记中,则忽略该标记。

width

定义最小宽度的整数。星号 (*) 允许 precision确定宽度。

precision

是输出字段最多输出的字符数,或为整数值输出的最小小数位数。星号 (*) 允许 argument确定精度。

{h | l} type

与字符类型 d、i、o、x、X 或 u 一起使用,用于创建 short int (h) 或 long int (l) 类型的值。

字符类型表示

d 或 I

带符号的整数

o

不带符号的八进制数

p

指针型

s

String

u

不带符号的整数

x 或 X

不带符号的十六进制数

说明  不支持float、双精度和单精度字符类型。

severity

用户定义的与消息关联的严重级别。用户可以使用从 0 到 18 之间的严重级别。19 到 25 之间的严重级别只能由 sysadmin 固定服务器角色成员使用。若要使用 19 到 25 之间的严重级别,必须选择 WITH LOG 选项。

注意  20 到 25 之间的严重级别被认为是致命的。如果遇到致命的严重级别,客户端连接将在收到消息后终止,并将错误记入错误日志和应用程序日志。

state

从 1 到 127 的任意整数,表示有关错误调用状态的信息。state的负值默认为 1。

argument

是用于取代在 msg_str 中定义的变量或取代对应于 msg_id 的消息的参数。可以有 0 或更多的替代参数;然而,替代参数的总数不能超过 20 个。每个替代参数可以是局部变量或这些任意数据类型:int1、int2、int4、char、varchar、binary 或 varbinary。不支持其它数据类型。

option

错误的自定义选项。option 可以是以下值之一:

值描述

LOG

将错误记入服务器错误日志和应用程序日志。记入服务器错误日志的错误目前被限定为最多 440 字节。

NOWAIT

将消息立即发送给客户端。

SETERROR

将 @@ERROR 的值设置为 msg_id 或 50000,与严重级别无关。

注释

如果使用 sysmessages错误并且是使用前面显示的 msg_str格式创建的消息,则将给所提供的 msg_id 的消息传递提供的参数(argument1、argument2 等等)。

当使用 RAISERROR 创建和返回用户定义的错误信息时,使用 sp_addmessage 添加用户定义的错误信息,使用 sp_dropmessage删除用户定义的错误信息。

当出现错误时,错误号将放在 @@ERROR 函数中,该函数存储最新生成的错误号。对于严重级别为 1 到 10 的消息,@@ERROR 的默认设置为0。

示例

A. 创建特定消息

下例显示可能出现的两种错误。第一种错误很简单,生成的是静态消息。第二种错误则是在尝试修改的基础上动态生成的。

CREATE TRIGGER employee_insupd

ON employee

FOR INSERT, UPDATE

AS

/* Get the range of level for this job type from the jobs table. */

DECLARE @@MIN_LVL tinyint,

@@MAX_LVL tinyint,

@@EMP_LVL tinyint,

@@JOB_ID smallint

SELECT @@MIN_LVl = min_lvl,

@@MAX_LV = max_lvl,

@@ EMP_LVL = i.job_lvl,

@@JOB_ID = i.job_id

FROM employee e, jobs j, inserted i

WHERE e.emp_id = i.emp_id AND i.job_id = j.job_id

IF (@@JOB_ID = 1) and (@@EMP_lVl <> 10)

BEGIN

RAISERROR (‘Job id 1 expects the default level of 10.’, 16, 1)

ROLLBACK TRANSACTION

END

ELSE

IF NOT @@ EMP_LVL BETWEEN @@MIN_LVL AND @@MAX_LVL)

BEGIN

RAISERROR (‘The level for job_id:%d should be between %d and %d.’,

16, 1, @@JOB_ID, @@MIN_LVL, @@MAX_LVL)

ROLLBACK TRANSACTION

END

B. 在 sysmessages 中创建特殊消息

下例显示如何通过执行 employee_insupd触发器获得与 RAISERROR 相同的效果,而 RAISERROR 使用给存储在 sysmessages表中的消息传递参数的方法。该消息通过 sp_addmessage 系统存储过程,以消息号 50005 被添加到 sysmessages 表中。

说明  下例仅供举例说明。

RAISERROR (50005, 16, 1, @@JOB_ID, @@MIN_LVL, @@MAX_LVL)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/216828.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午10:58
下一篇 2026年3月18日 上午10:58


相关推荐

  • aorg.gjt.mm.mysql.Driver和com.mysql.jdbc.Driver的关系

    aorg.gjt.mm.mysql.Driver和com.mysql.jdbc.Driver的关系今天写项目时,发现mysql驱动是 aorg.gjt.mm.mysql.Driver ,以前还真的没有见过,真是见识太少,于是记录一下。 com.mysql.jdbc.Driver的前身是org.gjt.mm.mysql.Driver,现在主要用com.mysql.jdbc.Driver,但为了保持兼容性保留了org.gjt.mm.mysql.Driver这个路径的引用。…

    2022年6月13日
    27
  • 卡巴斯基引领2019工控安全升级,开创智能+新未来「建议收藏」

    卡巴斯基引领2019工控安全升级,开创智能+新未来「建议收藏」2019年6月19日下午,2019工控安全态势暨卡巴斯基、京东方科技集团股份有限公司(以下简称“京东方”)与北京安渡神州科技有限公司(以下简称“安渡神州”)战略合作发布会在京举行。在全球知名信息安全厂商卡巴斯基领先安全技术的引领下,中国安全行业相关政府机构及行业组织、企事业单位领导、工控行业重要用户以及安全技术爱好者等代表共聚共享共促,本着领先科技赋能工业转型的核心原则,共同探讨未来工控安全领域新…

    2022年8月20日
    10
  • vue 部署上线清除浏览器缓存「建议收藏」

    vue 部署上线清除浏览器缓存「建议收藏」vue项目打包上线之后,每一次都会有浏览器缓存问题,需要手动的清除缓存。这样用户体验非常不好,所以我们在打包部署的时候需要尽量避免浏览器的缓存。下面是我的解决方案:一、修改根目录index.html在head里面添加下面代码<metahttp-equiv=”pragram”content=”no-cache”><metahttp-equiv=”cache-control”content=”no-cache,no-store,must-revalidate”>

    2022年7月18日
    17
  • es7新特性 includes用法

    es7新特性 includes用法返回数组是否包含某个元素 vararray1 1 2 3 console log array1 includes 2 expectedoutp true 转载于 https www cnblogs com mlh1421 p 10008831 html

    2026年3月16日
    1
  • windows下Git BASH安装

    windows下Git BASH安装下载安装 1 从 git 官网下载一个 git 安装包 官网下载地址 http www git scm com download 2 双击安装程序 进入欢迎界面点击 Next gt 3 阅读协议 点击 Next gt 4 选择安装位置 点击 Next gt 5 选择安装组件 这里可以使用默认选项 点击 Next gt 图标组件 Additional

    2026年3月9日
    2
  • Windows服务器补丁列表及介绍_操作系统打补丁我用WSUS[通俗易懂]

    你可曾遇到过使用Windows自带的UPDATE下载补丁速度非常慢,往往要等待3小时以上甚至更多呢?这还仅仅局限在关键更新上,要是把驱动和非关键更新也下载的话需要的时间会更长。如果公司只是在一个内网中员工计算机不容许上网的话你又是如何保证他们的补丁是最新的呢?恐怕使用默认的UPDATE都不能实现这些功能。  微软替我们想出了一个办法——使用WSUS。通过WSUS我们可以建立一个内部的UPDATE服…

    2022年4月15日
    555

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号