*&---------------------------------------------------------------------*
*& Report  YTST_RAINY015_03
*&
*&---------------------------------------------------------------------*
*&
*&
*&---------------------------------------------------------------------*

REPORT  ytst_rainy015_03.

*----------------------------------------------------------------------
*                          TYPES
*----------------------------------------------------------------------
TYPES: BEGIN OF ty_output,
         lifnr TYPE ekko-lifnr,             "供應商
         ebeln TYPE ekpo-ebeln,             "採購文件號碼
         ebelp TYPE ekpo-ebelp,             "採購文件的項目號碼
         txz01 TYPE ekpo-txz01,             "短文
         matnr TYPE ekpo-matnr,             "物料號碼
         werks TYPE ekpo-werks,             "地點
         lgort TYPE ekpo-lgort,             "庫存地點
         menge TYPE ekpo-menge,             "採購單數量
         meins TYPE ekpo-meins,             "單位
         wenge TYPE ekpo-menge,             "未清數量
         benge TYPE ekpo-menge,             "本次收料數量
       txt(50) TYPE c,                      "備註
           sel TYPE c,                      "選擇標誌
       END OF ty_output.
TYPES: ty_tab_output TYPE ty_output OCCURS 0.

TYPES: BEGIN OF ty_error,
    pstng_date TYPE budat,
      doc_date TYPE bldat,
       gm_code TYPE gm_code,
         plant TYPE werks_d,
      stge_loc TYPE lgort_d,
     move_type TYPE bwart,
     entry_qnt TYPE erfmg,
     entry_uom TYPE erfme,
     po_number TYPE bstnr,
       po_item TYPE ebelp,
       mvt_ind TYPE kzbew,
  message(100) TYPE c,
       txt(50) TYPE c,
           row TYPE bapi_line,
       END OF ty_error.
TYPES: ty_tab_error TYPE ty_error OCCURS 0.

DATA:gt_error TYPE ty_tab_error,
     wa_error TYPE ty_error.

DATA:gt_output TYPE ty_tab_output,
     wa_output TYPE ty_output.

DATA:l_tabix       TYPE sy-tabix,
     l_row         TYPE bapi_line,
     wa_output_tmp TYPE ty_output.

DATA:l_flag_create_success TYPE c.

DATA:lw_bapi_goodsmvt_header TYPE bapi2017_gm_head_01,
     lw_bapi_goodsmvt_code   TYPE bapi2017_gm_code,

lw_bapi_goodsmvt_headret TYPE bapi2017_gm_head_ret,
     l_bapi_materialdocument  TYPE bapi2017_gm_head_ret-mat_doc,
     l_bapi_matdocumentyear   TYPE bapi2017_gm_head_ret-doc_year,

lt_bapi_goodsmvt_item    TYPE STANDARD TABLE OF bapi2017_gm_item_create,
     wa_bapi_goodsmvt_item    TYPE bapi2017_gm_item_create,

lt_bapi_return           TYPE STANDARD TABLE OF bapiret2,
     wa_bapi_return           TYPE bapiret2.

*&G0.整理取得数据
SORT gt_output BY ebeln ebelp.

LOOP AT gt_output INTO wa_output.

wa_output_tmp = wa_output.
  AT NEW ebeln.

CLEAR:lw_bapi_goodsmvt_header,  lw_bapi_goodsmvt_code,
          lw_bapi_goodsmvt_headret, l_bapi_materialdocument,
          l_bapi_matdocumentyear,   lt_bapi_goodsmvt_item,
          lt_bapi_return.

*&G1.bapi_goodsmvt_hear 赋值(at new)
    lw_bapi_goodsmvt_header-pstng_date = sy-datum.
    lw_bapi_goodsmvt_header-doc_date   = sy-datum.

lw_bapi_goodsmvt_code-gm_code      = '01'.

ENDAT.

CLEAR wa_bapi_goodsmvt_item.
*&G2.bapi_goodsmvt_item 赋值()
  wa_bapi_goodsmvt_item-plant     = wa_output_tmp-werks.
  wa_bapi_goodsmvt_item-stge_loc  = wa_output_tmp-lgort.
  wa_bapi_goodsmvt_item-move_type = '101'.
  wa_bapi_goodsmvt_item-entry_qnt = wa_output_tmp-benge.
  wa_bapi_goodsmvt_item-entry_uom = wa_output_tmp-meins.
  wa_bapi_goodsmvt_item-po_number = wa_output_tmp-ebeln.
  wa_bapi_goodsmvt_item-po_item   = wa_output_tmp-ebelp.
  wa_bapi_goodsmvt_item-mvt_ind   = 'B'.
  APPEND wa_bapi_goodsmvt_item TO lt_bapi_goodsmvt_item.

AT END OF ebeln.

*&G3flag打上
    l_flag_create_success = 'Y'.

*&G4 CALL BAPI
    CALL FUNCTION 'BAPI_GOODSMVT_CREATE'
      EXPORTING
        goodsmvt_header  = lw_bapi_goodsmvt_header
        goodsmvt_code    = lw_bapi_goodsmvt_code
*       TESTRUN          = ' '
*       GOODSMVT_REF_EWM =
      IMPORTING
        goodsmvt_headret = lw_bapi_goodsmvt_headret
        materialdocument = l_bapi_materialdocument
        matdocumentyear  = l_bapi_matdocumentyear
      TABLES
        goodsmvt_item    = lt_bapi_goodsmvt_item
        return           = lt_bapi_return.

*       GOODSMVT_SERIALNUMBER   =
*       GOODSMVT_SERV_PART_DATA =
*       EXTENSIONIN             =
*       AFS_GOODSMVT_SKU        =

*&G5.如果失败,改flag 为‘N’.
    LOOP AT lt_bapi_return INTO wa_bapi_return WHERE type = 'A'
                                                  OR type = 'E'.
      l_flag_create_success = 'N'.
      EXIT.

ENDLOOP.

*&G6 BAPI后处理
    IF l_flag_create_success = 'Y'.
*&G6.1成功commit work,并形成日志
      CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
        EXPORTING
          wait = 'X'.

LOOP AT lt_bapi_goodsmvt_item INTO wa_bapi_goodsmvt_item.

wa_error-pstng_date = lw_bapi_goodsmvt_header-pstng_date.
        wa_error-doc_date   = lw_bapi_goodsmvt_header-doc_date.
        wa_error-gm_code    = lw_bapi_goodsmvt_code-gm_code.

MOVE-CORRESPONDING wa_bapi_goodsmvt_item TO wa_error.
        CONCATENATE '生成物料凭证编号为:' l_bapi_materialdocument INTO wa_error-message.
        MOVE '更新成功!' TO wa_error-txt.
        APPEND wa_error TO gt_error.
        CLEAR wa_error.

ENDLOOP.

ELSE.
*&6.2 失败rollback,并形成日志GT_ERROR
      CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
      CLEAR l_row.

LOOP AT lt_bapi_goodsmvt_item INTO wa_bapi_goodsmvt_item.

l_row = l_row + 1.
        wa_error-pstng_date = lw_bapi_goodsmvt_header-pstng_date.
        wa_error-doc_date   = lw_bapi_goodsmvt_header-doc_date.
        wa_error-gm_code    = lw_bapi_goodsmvt_code-gm_code.

MOVE-CORRESPONDING wa_bapi_goodsmvt_item TO wa_error.
        MOVE '更新失败!' TO wa_error-txt.
        wa_error-row = l_row.

READ TABLE lt_bapi_return INTO wa_bapi_return WITH KEY row = wa_error-row.
        IF sy-subrc = 0.
          wa_error-message = wa_bapi_return-message.
        ENDIF.
        APPEND wa_error TO gt_error.
        CLEAR wa_error.

ENDLOOP.

ENDIF.

IF l_flag_create_success = 'Y'.
*   IMPORTING
*     RETURN        =
    ELSE.
*   IMPORTING
*     RETURN        =

ENDIF.

ENDAT.

ENDLOOP.

CALL FUNCTION 'BAPI_GOODSMVT_CREATE'-(物料凭证创建)的更多相关文章

  1. BAPI_GOODSMVT_CREATE物料凭证增强字段

    项目MSEG 的 BAPI 表增强结构  BAPI_TE_XMSEG 抬头MKPF 的 BAIP 表增强 BAPI_TE_XMKPF 1. 在结构BAPI_TE_XMSEG中appending str ...

  2. 查看物料凭证MB03 /MIGO A04-显示,R02-物料凭证

    当货物移动操作后,可以使用事物码MB03.MIGO查询最近一次生成的物料凭证, 如果未知凭证号,Table:MKPF / AUFM/EKBE MKPF 抬头:物料凭证 KEY: MBLNR 物料凭证编 ...

  3. SAP MM 启用批次管理的物料MB21创建预留单据时批次号可以为空!

    SAP MM 启用批次管理的物料MB21创建预留单据时批次号可以为空! 如下预留, 批次号字段为空. 实际上该物料是有激活batch management的, For MB21, it is just ...

  4. 【MM系列】SAP 物料凭证增强

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]在SAP里查看数据的方法   前言部 ...

  5. 【ABAP系列】SAP ABAP 物料凭证增强

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 物料凭证增强 ...

  6. Object和Function谁先被创建

    http://bbs.csdn.net/topics/390772104#post-397284029

  7. SAP 订单状态跟踪

    *&--------------------------------------------------------------------- *& Program name:  *& ...

  8. SAP_FICO常用事务代码

    1.会计科目维护: FS00:总账科目主记录维护 FSP0:科目表中总账科目主记录维护 FSS0:公司代码中总账科目主记录维护 2.会计凭证创建 FB01:创建凭证 F-02:总账凭证创建(在FB01 ...

  9. 从new Function创建函数联想到MVC模式

    我们知道任何一个自定义函数都是Function构造器的实例,所以我们可以通过new Function的方式来创建函数,使用语法很简单, new Function(形参1, 形参2, ..., 形参N, ...

随机推荐

  1. SuperIndicator 一个专用打造轮播的类库

    Github地址:https://github.com/hejunlin2013/SuperIndicator,欢迎fork,star.著名Android-Universal-Image-Loader ...

  2. Git的提交忽略文件

    .gitingore文件内容如下 /target//.settings//.classpath/.project/logs/

  3. su、sudo、sudo su、sudo -i的用法和区别

    sudo : 暂时切换到超级用户模式以执行超级用户权限,提示输入密码时该密码为当前用户的密码,而不是超级账户的密码.不过有时间限制,Ubuntu默认为一次时长15分钟.su : 切换到某某用户模式,提 ...

  4. Django和Flask的区别以及运行流程

    Django: Python Web框架里比较有名当属Django,Django功能全面,它提供一站式解决方案,集成了MVT(Model-View-Template)和ORM,以及后台管理.但是缺点也 ...

  5. spring boot 读取配置文件(application.yml)中的属性值

    在spring boot中,简单几步,读取配置文件(application.yml)中各种不同类型的属性值: 1.引入依赖: <!-- 支持 @ConfigurationProperties 注 ...

  6. Mockito使用指南

    转载请标明出处:http://blog.csdn.net/shensky711/article/details/52771493 本文出自: [HansChen的博客] mock和Mockito的关系 ...

  7. 身份证识别接口编写的JAVA调用示例

    此java文章是基本聚合数据证件识别接口来演示,基本HTTP POST请求上传图片并接收JSON数据来处理. 使用前你需要通过 https://www.juhe.cn/docs/api/id/153 ...

  8. java debug

    java debug 模式下各button作用 F5:跳入方法  Step Into F6:向下逐行调试  Step Over F7:跳出方法  Step Return F8:直接跳转到下一个断点 D ...

  9. (三)初识jQuery

    进入jQuery官网:http://jquery.com/ 点击Download jQuery v3.1.1--->下载最新版本的jQuery版本--->放到你需要引入jQuery的文件中 ...

  10. sql 查询 一张表里面的数据 在另一张表中是否存在 和 比对两个集合中的差集和交集(原创)

    这两天在搞一个修复的小功能 需求: A表,B表,C表,日志文件 先筛选出A表和B表中都符合条件的数据,然后检查这些数据在C表中是否存在.如果不存在,就从日志中读取数据,存入C表中,如果存在,则不做操作 ...