4

我现在坚持这个超过 48 小时。我正在尝试使用 ADO 对象检索输出参数值。这是我的 vba 代码。

Function ExecuteCommand(cSp As String, aParameters As Variant) As Integer

Dim lnReturn As Integer
Dim loCommand As ADODB.Command
Dim prm As ADODB.Parameter
Dim rds As ADODB.Recordset

Set loCommand = New ADODB.Command

loCommand.CommandText = cSp
loCommand.CommandType = adCmdStoredProc
Set loCommand.ActiveConnection = goConnection
loCommand.NamedParameters = True

Dim iCount As Integer

For iCount = LBound(aParameters) To UBound(aParameters)
    If aParameters(iCount, 0) <> "" Then
        If aParameters(iCount, 1) = adNumeric Then
            Set prm = loCommand.CreateParameter(aParameters(iCount, 0), aParameters(iCount, 1), adParamInput)
            prm.Precision = 18
            prm.NumericScale = 0
            prm.Value = aParameters(iCount, 3)
        Else
            Set prm = loCommand.CreateParameter(aParameters(iCount, 0), aParameters(iCount, 1), adParamInput, , aParameters(iCount, 3))
        End If
        loCommand.Parameters.Append prm
    End If
Next

Set prm = loCommand.CreateParameter("@returnval", adInteger, adParamOutput, , lnReturn)
loCommand.Parameters.Append prm

Set rds = loCommand.Execute
' Check the value of lnReturn and it's zero here.
lnReturn = loCommand.Parameters("@returnval").Value


ExecuteCommand = lnReturn

End Function

我的存储过程如下...

USE [table_name]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER PROCEDURE [dbo].[spname]
@para1 int,
@para2 int,
@para3 int,
@returnval int Output
AS
BEGIN

SET NOCOUNT ON;

SELECT * FROM type_table WHERE type1=@para1 and type2=@para2 and type3=@para3
SET @returnval = @@ROWCOUNT
RETURN @returnval
END

这些是我的发现

lnReturn = 0 always
rds.EOF = False
rds.RecordCount = -1

我的问题是我没有得到正确的受影响行数,即 1。我不确定代码有什么问题,有人可以帮帮我吗?

4

3 回答 3

4

这可能是因为,正如 Technet 所说,在输出参数和返回值的情况下,直到 Recordset 对象的数据被完全提取或 Recordset 已关闭,才会返回值。

如果您对 SELECT 语句返回的数据不感兴趣,请关闭您的 RecordSet ( rds.Close),或者循环遍历它,直到您读取所有行。

顺便说一句,如果您对 select 语句返回的数据不感兴趣,只对行数感兴趣,那么不返回它会更有效。因此,如果您可以修改您的 SP,您可以将其更改为:

SELECT @returnval = COUNT(*) FROM type_table WHERE type1=@para1 and type2=@para2 and type3=@para3
于 2013-11-12T12:22:32.620 回答
0

如果您不希望将记录集作为存储过程调用的一部分,请使用 cmd1->Execute(NULL, NULL, ADO::adExecuteNoRecords);

于 2014-09-18T05:30:37.027 回答
0

SET NOCOUNT ON;从您的程序中删除后试一试

我想这会对你有所帮助。SET NOCOUNT ON;如果您在过程中设置,则不会返回受影响的行数。

于 2013-11-12T12:16:10.517 回答