SAP接口编程之 RFC系列(04) : 动态调用SAP函数

对于Function module(FM)的调用,VB语言可以使用动态调用的方法,代码看起来比较简洁。其他语言是否可以用这种方式,没有测试过。

动态调用FM,Exception必须作为第一个参数。直接看代码吧。

Public Sub GetCompanyCodeData_Method2()
    Dim functions As SAPFunctionsOCX.SAPFunctions

    Dim ret As SAPFunctionsOCX.Structure          'return'
    Dim coCdDetail As SAPFunctionsOCX.Structure   'company code detail'
    Dim addrData As SAPFunctionsOCX.Structure     'address data'
    Dim ex As String                              'exception'

    Call Logon

    ' 如果连接成功,调用BAPI'
    If sapConnection.IsConnected <> tloRfcConnected Then
       MsgBox "连接失败."
       Exit Sub
    End If

    Set functions = New SAPFunctionsOCX.SAPFunctions
    Set functions.Connection = sapConnection

    ' 动态调用BAPI_COMPANYCODE_GETDETAIL'
    ' exception必须放在第一个参数位置'
    functions.BAPI_COMPANYCODE_GETDETAIL _
                ex, _
                COMPANYCODEID:="0001", _
                RETURN:=ret, _
                COMPANYCODE_DETAIL:=coCdDetail, _
                COMPANYCODE_ADDRESS:=addrData

    ' 确定没有Exceptions'
    If ex <> "" Then
        Exit Sub
    End If

    ' 输出company code detail'
    Dim i As Integer
    For i = 1 To coCdDetail.ColumnCount
        Debug.Print coCdDetail.ColumnName(i) & ":" & coCdDetail.Value(i)
    Next
    
    Call Logoff
End Sub

你可能感兴趣的:(SAP接口编程之 RFC系列(04) : 动态调用SAP函数)