前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MSSQL触发器语句自定义错误,VFP怎么获取

MSSQL触发器语句自定义错误,VFP怎么获取

作者头像
加菲猫的VFP
发布2021-12-21 20:47:39
6360
发布2021-12-21 20:47:39
举报

社群里wang先生提问,触发器语句错误,核验错误信息如可获取?

wang先生想在触发器中触发出业务失败,并返回正确的错误信息。

社群的科大侠迅速给出了解决方案。

科大侠的解决方案

其实在这里就要应用SQL的触发错误函数了.

server数据库中raiserror的作用就和VFP的ERROR,还有TRY中的throw一样,用于抛出一个异常或错误。当然这个错误要能被程序捕捉到。 有很多很多狐友,其实没有掌握ERROR和TRY的用法,如果真正掌握了这两个命令的用法,你的程序的稳定性将大大增强。

在SQL2000的查询分析器里运行如下的语句

CREATE PROCEDURE [dbo].[test1] AS 
raiserror ('我是一个错误信息',16,1)
create table testdbf (xxx varchar(50))
GO

在VFP窗口运行中如下的命令(请提前配置好账套)

oDBSQLHelper=Newobject("mssqlhelper","mssqlhelper.prg")
If oDBSQLHelper.ExeCuteSql("exec test1 ")<0
    ?oDBSQLHelper.errmsg
    Return
Endif
?"ok"

可以看到运行结果

运行结果

不使用祺佑三层开发框架的可以使用Aerror函数来捕捉错误 。

存储过程是这样处理,触发器也是一样的。

以下这段用法来自网络 https://www.cnblogs.com/railgunman/p/6659641.html

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 }中包含了一些代替符,那么这个参数就是代替符的具体的值,这个和祺佑三层开发框架(猫框)中的stringFormat用法是一样的,当然学过C的就更加明白了。示例如下:

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  
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-12-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 加菲猫的VFP 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、{ msg_id | msg_str | @local_variable }
  • 二、severity
  • 三、state
  • 四、[ ,argument [ ,…n ] ]
  • 五、[ WITH option [ ,…n ] ]
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档