1

需要帮助,我正在尝试使用 RFC_READ_TABLE 从 SAP 获取销售数据,但不知道如何将 OPTIONS 和 FIELDS 参数传递给 SAP。这是我的应用程序的示例代码。

连接正常,执行后出现异常“DATA_BUFFER_EXCEEDED”

public void RFC_READ_TABLE()
    {
        try
        {
            ECCDestinationConfig cfg = new ECCDestinationConfig();

            RfcDestinationManager.RegisterDestinationConfiguration(cfg);

            RfcDestination dest = RfcDestinationManager.GetDestination("ABI_ERP");

            RfcRepository repo = dest.Repository;

            IRfcFunction fn = repo.CreateFunction("RFC_READ_TABLE");

            fn.SetValue("QUERY_TABLE", "VBAP");

            fn.GetTable("DATA");

            fn.Invoke(dest);

            var companyCodeList = fn.GetTable("VBAP");

            var companyDataTable = companyCodeList.ToDataTable("VBAP");

            dataGridView1.DataSource = companyDataTable;
        }
        catch (RfcBaseException x)
        {

            MessageBox.Show("Some problems in programe execution. Check entered data, and try again." +
                                        "\n" +
                                        "\n<SAP Remote Execution Error>" +
                                        "\n" +
                                        "\nAdditional Information on Error: " + x.Message, "Oops, Runtime Error");
        }
    }
4

3 回答 3

2

RFC_READ_TABLE不是用于读取销售订单数据的理想功能模块(它实际上是为快速-n'-脏表读取而设计的,没有其他东西存在)。我将调查以下支持 RFC 的功能模块:

  • BAPI_SALESORDER_GETLIST- 获取销售文件清单
  • BAPISDORDER_GETDETAILEDLIST- 阅读单个销售文件的详细信息

如果您查看功能组2032销售和分销->销售->交易中的销售订单BAPI,您会发现其他可能有帮助的。

于 2015-06-24T09:43:51.943 回答
1

您应该只定义您真正需要的列,例如SELECTSQL 中的 after,即销售单据、项目和物料编号:

IRfcTable fieldsTable = fn.GetTable("FIELDS");
fieldsTable.Append();
fieldsTable.SetValue("FIELDNAME", "VBELN"); //Sales Document
fieldsTable.Append();
fieldsTable.SetValue("FIELDNAME", "POSNR"); // Sales Document Item
fieldsTable.Append();
fieldsTable.SetValue("FIELDNAME", "MATNR"); // Material number

如果您不这样做,则调用将由于超出数据缓冲区而失败,正如您所提到的。这是因为函数中的DATA结构RFC_READ_TABLE是类型的TAB512,这意味着每行最多只能包含 512 个字符。您查询的表中组合的所有列的内容长度 ( VBAP) 约为 1500 个字符。在这里您可以看到每个字段的长度。

然后您还希望过滤表,类似于WHERESQL 中的子句。

IRfcTable options = fn.GetTable("OPTIONS");
options.Append();
options.SetValue("TEXT", "VBELN = '000000000' AND POSNR = '000000'");
options.Append();
options.SetValue("TEXT", " OR VBELN = '000000001' AND POSNR = '000001'");

在这里您还需要小心,因为每个选项文本的长度最多应为 72 个字符。如果您需要多个或更长WHERE的子句,只需附加新选项,如文件。我注意到,这OR会导致某些表出现一些性能问题。

设置函数的这两个属性后,您应该能够成功调用它。

于 2019-07-25T08:45:33.597 回答
0

通过使用 RFC_READ_TABLE 的“选项”和“字段”表选项来缩小查询范围。

于 2015-06-24T09:32:56.353 回答