设为首页 收藏本站
查看: 1126|回复: 0

[经验分享] SAP BDC批量导入数据

[复制链接]

尚未签到

发表于 2015-9-19 14:22:03 | 显示全部楼层 |阅读模式
  在做好录屏以后SHDB。
  首先必须定义BDC变量:
  * BDC table
DATA: t_bdc       LIKE bdcdata  OCCURS 0 WITH HEADER LINE,
           t_bdcmsg LIKE bdcmsgcoll  OCCURS 0 WITH HEADER LINE.
DATA: BEGIN OF t_log OCCURS 0,
               information(289) TYPE c,   "返回信息
           END OF t_log.
DATA: v_mode TYPE c VALUE 'N'.
  其中TABLE t_bdc中记录的具体的操作步骤,而TABLE t_bdcmsg是记录系统返回的信息,成功与否都记录到自定义的信息表t_log中。
  先写个记录BDC的函数:
  FORM. fm_set_bdc TABLES t_bdc STRUCTURE bdcdata
                                                     USING u_sign TYPE c
u_par1
u_par2.
  CLEAR: t_bdc.
IF u_sign = 'X'.
   t_bdc-program = u_par1.
   t_bdc-dynpro = u_par2.
   t_bdc-dynbegin = u_sign.
ELSE.
   t_bdc-fnam = u_par1.
   t_bdc-fval = u_par2.
ENDIF.
APPEND t_bdc.
ENDFORM.
  然后写入T_bdc:
  PERFORM. fm_set_bdc:
    TABLES t_bdc USING 'X'    'SAPMV45A'     '0102',
    TABLES t_bdc USING ' '    'BDC_OKCODE'  '/00',
    TABLES t_bdc USING ' '    'VBAK-VBELN'   it_display-vbeln,
    TABLES t_bdc USING 'X'   'SAPMV45A'      '4001',
    TABLES t_bdc USING ' ' '   VBKD-BSTDK'   '2006.10.01'.
  因为此处是修改操作,所以要切记写入的只是你修改的数据,千万别把订单本来的数据也写入t_bdc,如果写入则会把需要修改的所有订单都该成举例的订单的数据,而我们需要修改的仅仅是增加一个PO DATE“2006.10.01”。
  然后是调用事物代码:
  CALL TRANSACTION 'VA42'
           USING t_bdc
           MODE v_mode "Background performance
           UPDATE 'S' "local updata
           MESSAGES INTO t_bdcmsg. "all message table
  v_mode是显示模式:
  “A”表示显示每一步操作步骤,
  “N”表示不显示步骤,
  “E”表示当出现错误的时候显示出错的位置。
  系统信息写入到t_bdc中。
  最后是收集系统信息(成功与否,要是失败,失败的原因)并输出到SAP程序屏幕
  READ TABLE t_bdcmsg WITH KEY msgtyp = 'S'
                                                    msgid = 'V1'
                                                    msgnr = '311'.         "批导入成功的标志,可以自己debug表t_bdcmsg中去找.
IF sy-subrc EQ 0.
     CONCATENATE '订单号码:'
                               it_display-vbeln
                              ',项目号:'
                              it_display-posnr
                              '修改成功' INTO t_log.
    APPEND t_log.
    CLEAR t_log.
ELSE.
LOOP AT t_bdcmsg.
    IF t_bdcmsg-msgtyp = 'E'
        OR t_bdcmsg-msgv1 <> ''
        OR t_bdcmsg-msgv2 <> ''
        OR t_bdcmsg-msgv3 <> ''
        OR t_bdcmsg-msgv4 <> ''.
MESSAGE ID t_bdcmsg-msgid                   &#8220;收集错误信息,并写入自定义的表t_log中。
                TYPE 'S'
                NUMBER t_bdcmsg-msgnr
                WITH t_bdcmsg-msgv1
    t_bdcmsg-msgv2
    t_bdcmsg-msgv3
    t_bdcmsg-msgv4
    INTO t_log-information.
CONCATENATE '订单号码:'
                        it_display-vbeln
                       ',项目号:'
  it_display-posnr
                       '出错:'
                       t_log-information
INTO t_log-information.
APPEND t_log.
CLEAR t_log.
ENDIF.
ENDLOOP.
ENDIF.
  LOOP AT t_log.                          "显示出错信息
  WRITE:/ t_log-information.
  ENDLOOP.
  到此一个批导入程序基本完成。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-115910-1-1.html 上篇帖子: SAP BPC 查看系统日志 下篇帖子: SAP BPC表单中使用VBA函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表