0

我正在尝试从 an接收varchar(max)输出,但出现上述错误,即当我执行inparamstored procedureData type 0x23 is a deprecated large object, or LOB, but is marked as output parameterSPvb.net

我试过使用SQLNCLI11连接字符串,没有运气我试过设置Datatypecompatibility=80,没有运气

提前致谢。

这是我的代码:

 Private Sub Button1_Click(sender As Object, e As EventArgs) Handles     Button1.Click
    Dim cmd As ADODB.Command
    Dim Rs As ADODB.Recordset
    Dim prm As ADODB.Parameter
    Dim db As New ADODB.Connection
    Dim PromoRejectDesc As String = ""

    db.ConnectionString = "Provider=SQLNCLI11;UID=user;Pwd=password;Database=POSData;Server=localhost;DataCompatibility=80;MARS Connection=True"

    db.Open()

    cmd = New ADODB.Command
    cmd.ActiveConnection = db
    cmd.CommandType = ADODB.CommandTypeEnum.adCmdStoredProc
    cmd.CommandText = "DBO.proc_PromoRejectingFactors"

    prm = cmd.CreateParameter("@CustID", ADODB.DataTypeEnum.adInteger, ADODB.ParameterDirectionEnum.adParamInput)
    prm.Value = 1050009326
    cmd.Parameters.Append(prm)
    prm = cmd.CreateParameter("@BranchID", ADODB.DataTypeEnum.adInteger, ADODB.ParameterDirectionEnum.adParamInput)
    prm.Value = 101
    cmd.Parameters.Append(prm)
    prm = cmd.CreateParameter("@FulfillmentChannel", ADODB.DataTypeEnum.adInteger, ADODB.ParameterDirectionEnum.adParamInput)
    prm.Value = 1
    cmd.Parameters.Append(prm)
    prm = cmd.CreateParameter("@Tender", ADODB.DataTypeEnum.adInteger, ADODB.ParameterDirectionEnum.adParamInput)
    prm.Value = 0
    cmd.Parameters.Append(prm)

    prm = cmd.CreateParameter("@CreditCard", ADODB.DataTypeEnum.adInteger, ADODB.ParameterDirectionEnum.adParamInput)
    prm.Value = -1
    cmd.Parameters.Append(prm)

    prm = cmd.CreateParameter("@ExcludePromo", ADODB.DataTypeEnum.adVarChar, ADODB.ParameterDirectionEnum.adParamInput, 1000)
    prm.Value = ""
    cmd.Parameters.Append(prm)

    prm = cmd.CreateParameter("@PromoRejectDesc", ADODB.DataTypeEnum.adLongVarChar, ADODB.ParameterDirectionEnum.adParamOutput, 9999)
    cmd.Parameters.Append(prm)

    Rs = cmd.Execute
    If Rs.State = 1 Then
        PromoRejectDesc = prm.Value
        MsgBox(PromoRejectDesc)
    End If
End Sub
4

1 回答 1

1

好的,我已经解决了我的问题。

首先,我将 CursorLocation 设置为 adUseClient

db.ConnectionString = "Provider=SQLNCLI11;UID=user;Pwd=password;Database=POSData;Server=localhost;DataCompatibility=80;MARS Connection=True"
db.CursorLocation = ADODB.CursorLocationEnum.adUseClient
db.Open()

然后,对于输出参数数据类型,我使用了 adBStr

prm = cmd.CreateParameter("@PromoRejectDesc", ADODB.DataTypeEnum.adBSTR, ADODB.ParameterDirectionEnum.adParamOutput, 999999)
    cmd.Parameters.Append(prm)

之后一切正常!

顺便说一句,我收到了 18,255 个(长度)字符。

于 2016-06-23T04:53:18.310 回答