SAP接口编程之 RFC系列(06) : Table作为输入参数

调用SAP FM的时候,如果table作为输入参数,调用前需要填充。本篇讲述填充的方法,以RFC_READ_TABLE为例。
RFC_READ_TABLE用于读取SAP数据库表的结构和数据。使用方法如下 IMPORTING QUERY_TABLE:读取的表名 DELIMITER:输出字段(DATA参数)之间的分隔符 NO_DATA:输入’X’时,不向传出表DATA输出数据 ROWSKIP:输出的第一条数据的行号(从0开始) ROWCOUNT:从ROWSKIP开始,一共输出的数据行数(0代表所有数据) TABLE: OPTIONS:表查询条件,比如SKA1表,KTOPL = ‘Z900’表示查收Z900账目表的会计科目数据,留空 代表所有数据。 FIELDS:输出的表字段,留空代表输出所有字段。 DATA:输出的数据记录。
假设我们要读取Z900账目表有所有会计科目,并且只需要输出KTOPL(账目表)和SAKNR(会计科目)两个字段

Public Sub Read_Table_SKA1()
    Dim functions As SAPFunctionsOCX.SAPFunctions
    Dim options As SAPTableFactoryCtrl.Table
    Dim fields As SAPTableFactoryCtrl.Table
    Dim data As SAPTableFactoryCtrl.Table

    Call Logon

    Set functions = New SAPFunctions
    Set functions.Connection = sapConnection

    Dim fm As SAPFunctionsOCX.Function
    Set fm = functions.Add("RFC_READ_TABLE")

    fm.Exports("QUERY_TABLE").Value = "SKA1" ' 要查询的表'
    fm.Exports("DELIMITER").Value = ","      ' Data表要存储的数据以逗号分割'

    Set options = fm.Tables("OPTIONS")
    Set fields = fm.Tables("FIELDS")
    Set data = fm.Tables("DATA")

    ' 以下是表参数填充的方法'
    ' options表参数限定要选择的数据'
    options.FreeTable
    options.AppendRow
    options(1, "TEXT") = " KTOPL = 'Z900' " '第一行列名为TEXT的列增加选择条件'

    ' fields表参数限定要输出的列,如果不限定'
    ' 默认输出所有列'
    ' 我只想输出KTOPL和SAKNR两列'
    fields.FreeTable
    fields.AppendRow
    fields(1, "FIELDNAME") = "KTOPL"

    fields.AppendRow
    fields(2, "FIELDNAME") = "SAKNR"

    fm.Call
    ' 如果有Exception , 说明有错误产生'
    If fm.Exception <> "" Then
        Debug.Print fm.Exception
        Exit Sub
    End If

    ' 将DATA输出到立即窗口'
    Dim row As SAPTableFactoryCtrl.row
    Dim col As SAPTableFactoryCtrl.Column

    ' 按行读取,DATA表只有一列'
    For Each row In data.Rows
        Debug.Print row.Value("WA")
    Next

    Call Logoff
End Sub

表参数填充的方法:
填充第一行第一列: sometable(1, 1) = “XXX”
或者根据列名:sometable(1, “FIELDNAME”) = “XXX”
因为table有一个RowCount属性,我们总是可以将RowCount用于代码中,增加灵活性。比如上面的代码可以写成:

fields.FreeTable
fields.AppendRow
fields(fields.RowCount, "FIELDNAME") = "KTOPL"

fields.AppendRow
fields(fields.RowCount, "FIELDNAME") = "SAKNR"
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容