SAP RFC 输入一张表(C# 使用 SapNwRfc 二)

SapNwRfc中的配置参数,记录日志关闭 Trace=0,可以得到很好的性能。

有网友在问,SAP RFC返回多张表(C# 使用 SapNwRfc 一)中如何输入一张表的数据,正好博主也遇到了这个场景,今天做了一个DEMO,详细代码如下:

using SapNwRfc;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace saprfc2024table
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void toolStripButton1_Click(object sender, EventArgs e)
        {
            callsap();
        }

        void callsap()
        {
            string connectionString = "AppServerHost=xxx.xxx.xxx.xxx; SystemNumber=00; User=xxxxxx;Password=xxxxxxx Client=700; Language=ZH; PoolSize=5; Trace=0";
            var connection = new SapConnection(connectionString);
            connection.Connect();
            toolStripStatusLabel1.Text = "Logon SAP Server...";

        
            /*
            InputItem[] inputItem  = new InputItem[]
            {
                new InputItem { WERKS = "1003"  },
                new InputItem { WERKS = "1003"  },

            };
            */


            //新建一个对象数组,大小10000
            InputItem[] inputItem = new InputItem[10000];
            for (int i = 0; i < 10000; i++)
            {
                inputItem[i] = new InputItem { WERKS = "1003",ZMENG = i };
            }

            //对象数组交给对象表
            InputTable inputTable = new InputTable();
            inputTable.Items = inputItem;
            
            //调用函数,输入是一张表10000条数据,输出是函数返回的结果
            var someFunction = connection.CreateFunction("ZSAP_PP_APS_XXXXX_IN");
            var result = someFunction.Invoke<ReturnTable>(inputTable);
            

            //显示返回的结果
            foreach ( var item in result.Items ) 
            { 
                listBox1.Items.Add(item.STATUS + " " + item.MESSAGE);
            }
        }
    }


    class InputTable 
    {
        [SapName("IT_INPUT")]
        public InputItem[] Items { get; set; }
    }



    class InputItem
    {
        [SapName("WERKS")]
        public string WERKS { get; set; }

        [SapName("MATNR")]
        public string MATNR { get; set; }

        [SapName("ATWRT")]
        public string ATWRT { get; set; }

        [SapName("Z_SALE_PACK")]
        public string Z_SALE_PACK { get; set; }

        [SapName("ATWRT1")]
        public string ATWRT1 { get; set; }

        [SapName("ATWRT2")]
        public string ATWRT2 { get; set; }

        [SapName("ETDAT")]
        public string ETDAT { get; set; }

        [SapName("ZMENG")]
        public double ZMENG { get; set; }

        [SapName("ZIEME")]
        public string ZIEME { get; set; }

    }



    class ReturnTable 
    {
        [SapName("ET_RETURN")]
        public ReturnItem[] Items { get; set; }   
    }


    class ReturnItem
    {
        [SapName("STATUS")]
        public string STATUS { get; set; }

        [SapName("MESSAGE")]
        public string MESSAGE  { get; set; }
        
    }



}

只用了1秒钟,SAP中灌入了10000条数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘欣的博客

你将成为第一个打赏博主的人!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值