lhzy2015 2015-04-17 06:39 采纳率: 0%
浏览 1723
已结题

SQL2000存储过程错误抓取问题

我程序用的是VB6.0,数据库是SQL2000,
插入一个存储过程
Create PROCEDURE PROC_RdrecordsNoBeff
AS

begin

BEGIN TRANSACTION

delete from systasklog
delete from Mat_sup where PartID=959
if   @@error<>0
BEGIN
    --提示错误  并退出   
    ROLLBACK TRANSACTION
    RAISERROR('资产类物料,单件号不允许为空!',11,1)
    return 1 
END 


COMMIT TRANSACTION

end
GO
比如这样一个存储过程,delete from systasklog这句执行不会出错,
这句delete from Mat_sup where PartID=959执行会出错

在查询分析器我当然可以看到错误信息,
问题来了,我在VB里面如何抓取具体错误信息呢,
我在VB中是这样调用的:
Public Function ExecPROC() As Boolean
On Error GoTo Errcon
Dim Rd As New ADODB.Command

Rd.ActiveConnection = Cn
Rd.CommandText = "PROC_RdrecordsNoBeff"
Rd.CommandType = adCmdStoredProc
Rd.Execute

If Rd.Parameters(0) = 1 Then
ExecPROC = False
Exit Function
End If

ExecPROC = True
Exit Function
Errcon:
MsgBox Err.Description
End Function

请问该如何改动,才能抓取具体错误信息?

  • 写回答

3条回答 默认 最新

  • 232frb 2015-04-17 16:27
    关注

    你不要在程序中抓取错误信息
    你可以这样
    if @@error<>0
    BEGIN
    --提示错误 并退出

    ROLLBACK TRANSACTION
    select 'F' as rel, '资产类物料,单件号不允许为空!' as msg
    return 1
    END
    这样你你的返回值就是一个表 而表中就包含你的错误信息 就不用再程序中捕捉存储过程里面raiseerror的信息了

    评论

报告相同问题?

悬赏问题

  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了