记录批量取消门店交货单过账,VL09,WS_REVERSE_GOODS_ISSUE

文章描述了一个使用ABAP编程语言实现的ALV界面,涉及数据筛选、权限验证、从数据库获取数据、处理冲销操作并显示结果,以及ALV网格的显示和用户交互功能。
摘要由CSDN通过智能技术生成
TYPES: BEGIN OF ty_data.
        INCLUDE TYPE ZSDF_077_LOG.
TYPES: END OF ty_data.
DATA: LT_DATA TYPE TABLE OF ty_data,
      LS_data TYPE ty_data.
DATA:
      FIELDCATALOG    TYPE SLIS_T_FIELDCAT_ALV WITH HEADER LINE,
      GD_LAYOUT       TYPE SLIS_LAYOUT_ALV,
      GD_REPID        LIKE SY-REPID,
      I_EVENTS        TYPE SLIS_T_EVENT
      .
*选择屏幕
SELECTION-SCREEN BEGIN OF BLOCK BLK1 WITH FRAME TITLE T1.
SELECT-OPTIONS :
                 S_KUNNR   FOR LIKP-KUNNR,
                 S_VBELN   FOR VBUK-VBELN OBLIGATORY,
                 S_WADATE  FOR LIKP-WADAT_IST,
                 S_WEEKS   FOR LIPS-WERKS.
      PARAMETERS S_WADAT   TYPE LIKP-WADAT.
      PARAMETERS S_DELAY   TYPE i DEFAULT '1' . 
SELECTION-SCREEN END OF BLOCK BLK1.

*权限
AUTHORITY-CHECK OBJECT 'S_TCODE'
ID 'TCD'   FIELD 'VL09'.
IF SY-SUBRC <> 0.
  MESSAGE '您没有访问权限' TYPE 'E'.
  STOP.
ENDIF.

*获取数据
PERFORM FROM_GET_DATA.
PERFORM FROM_FIELDCATALOG.
PERFORM FROM_LAYOUT.
PERFORM FROM_DISPLAY_ALV.

FORM from_get_data .
  DATA WADAT TYPE LIKP-WADAT_IST.
  WADAT = S_WADAT.
  IF S_WADAT IS INITIAL.
    SELECT
        P~VBELN
        P~WADAT_IST
        P~KUNNR
        L~WERKS
        P~WADAT_IST AS WADAT
      INTO CORRESPONDING FIELDS OF TABLE LT_DATA
      FROM likp AS P
      INNER JOIN lips AS L ON L~vbeln = P~vbeln
      INNER JOIN VBUK  AS V ON P~VBELN = V~VBELN
     WHERE L~VBELN IN S_VBELN
       AND P~WADAT_IST IN S_WADATE
       AND P~KUNNR IN S_KUNNR
       AND L~WERKS IN S_WEEKS
       AND WBSTK = 'C'
       AND FKSTK = 'A'.

  ELSE.
    SELECT
        P~VBELN
        P~WADAT_IST
        P~KUNNR
        L~WERKS
      INTO CORRESPONDING FIELDS OF TABLE LT_DATA
      FROM likp AS P
      INNER JOIN lips AS L ON L~vbeln = P~vbeln
      INNER JOIN VBUK  AS V ON P~VBELN = V~VBELN
     WHERE L~VBELN IN S_VBELN
       AND P~WADAT_IST IN S_WADATE
       AND P~KUNNR IN S_KUNNR
       AND L~WERKS IN S_WEEKS
       AND WBSTK = 'C'
       AND FKSTK = 'A'.
    ls_data-WADAT = S_WADAT.
    MODIFY LT_DATA FROM ls_data TRANSPORTING WADAT WHERE WADAT = '00000000' .
  ENDIF.

*  排序
SORT LT_DATA BY VBELN.
*删除相邻的重复项
DELETE ADJACENT DUPLICATES FROM LT_DATA COMPARING VBELN.
ENDFORM.

FORM from_fieldcatalog .
CLEAR  FIELDCATALOG.
  FIELDCATALOG-FIELDNAME   = 'VBELN'.
  FIELDCATALOG-SELTEXT_M   = '交货单号'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  FIELDCATALOG-KEY         = 'X'.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'KUNNR'.
  FIELDCATALOG-SELTEXT_M   = '门店编码'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  FIELDCATALOG-KEY         = 'X'.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'WADAT_IST'.
  FIELDCATALOG-SELTEXT_M   = '过账日期'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  FIELDCATALOG-KEY         = 'X'.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'WADAT'.
  FIELDCATALOG-SELTEXT_M   = '冲销日期'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  FIELDCATALOG-KEY         = 'X'.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'WERKS'.
  FIELDCATALOG-SELTEXT_M   = '发货工厂'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  FIELDCATALOG-KEY         = 'X'.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'TYPE'.
  FIELDCATALOG-SELTEXT_M   = '冲销状态'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.

  FIELDCATALOG-FIELDNAME   = 'MESSAGE'.
  FIELDCATALOG-SELTEXT_M   = '消息提示'.
  FIELDCATALOG-OUTPUTLEN   = 10.
  APPEND FIELDCATALOG TO FIELDCATALOG.
  CLEAR  FIELDCATALOG.
ENDFORM.

FORM from_display_alv .
  GD_REPID = SY-REPID.

  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      I_CALLBACK_PROGRAM = GD_REPID
      i_callback_pf_status_set = 'ALV_PF_STATUS '
      i_callback_user_command  = 'ALV_USER_COMMAND'
      IS_LAYOUT          = GD_LAYOUT
      IT_FIELDCAT        = FIELDCATALOG[]
      I_SAVE             = 'X'
      IT_EVENTS          = I_EVENTS[]
    TABLES
      T_OUTTAB           = LT_DATA
    EXCEPTIONS
      PROGRAM_ERROR      = 1
      OTHERS             = 2.
ENDFORM.

FORM alv_pf_status USING rt_extab TYPE slis_t_extab.
  SET PF-STATUS 'STAT'.
ENDFORM.
FORM alv_user_command USING r_ucomm LIKE sy-ucomm
                            rs_selfield TYPE slis_selfield.
  CASE r_ucomm.
    WHEN 'SEND'.
      PERFORM from_send.
      rs_selfield-refresh = 'X'.
      rs_selfield-col_stable ='X'.
      rs_selfield-row_stable ='X'.
  ENDCASE.
ENDFORM.

FORM from_layout .
  GD_LAYOUT-COLWIDTH_OPTIMIZE = 'X'.
  GD_LAYOUT-ZEBRA             = 'X'.
ENDFORM.

FORM from_send .
  DATA: LS_MESG TYPE TABLE OF MESG WITH HEADER LINE.
  DATA: ZTEXT TYPE MESG-TEXT,
        ZMSGTY TYPE MESG-MSGTY.
  DATA: LV_VBTAP LIKE LIKP-VBTYP.
  DATA LS_DATAS TYPE ty_data.
  DATA: lv_delay TYPE i.
  lv_delay = S_DELAY.
  
LOOP AT LT_DATA INTO LS_DATA.
  LS_DATAS = LS_DATA.
    AT END OF VBELN.
      WAIT UP TO lv_delay SECONDS. "批量冲销添加等待时间,默认为1秒。
      CALL FUNCTION 'WS_REVERSE_GOODS_ISSUE'
        EXPORTING
          I_VBELN                   = LS_DATAS-VBELN
          I_BUDAT                   = LS_DATAS-WADAT
          I_TCODE                   = 'VL09'
          I_VBTYP                   = 'J'
        TABLES
          T_MESG                    = LS_MESG
        EXCEPTIONS
          ERROR_REVERSE_GOODS_ISSUE = 1
          OTHERS                    = 2.
      IF SY-SUBRC =  0.
        COMMIT WORK.
       ZTEXT =  '冲销成功'.
       ZMSGTY = 'S'.
      ELSE.
        ZTEXT = '冲销失败'.
        ZMSGTY = 'E'.
      ENDIF.
      LS_DATAS-message = ZTEXT.
      LS_DATAS-type = ZMSGTY.
      LS_DATAS-ernam = sy-uname.
      LS_DATAS-erdat = sy-datum.
      LS_DATAS-erzet = sy-uzeit.
      MODIFY LT_DATA FROM LS_DATAS.
   ENDAT.
  ENDLOOP.
ENDFORM.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 首先,需要确定您所提到的 "增强点" 是什么,这样我才能给出合适的回答。 在 SAP 系统中,交货单是在销售订单的基础上产生的,用于记录产品的交付情况。在 ABAP 程序中,可以使用函数模块来进行交货单过账操作。常用的函数模块有: - BAPI_OUTB_DELIVERY_CONFIRM 实现交货单过账,包括物料出库和交货单过账。 - VL01N_SAVE_AND_CHECK 在交货单创建和修改的过程中,可以使用这个函数模块来保存并检查数据的有效性。 如果您想对交货单过账的流程进行增强,可以使用以下方法: - 在交货单过账之前,使用 ABAP 代码来执行数据检查和转换,以确保数据的完整性和一致性。 - 在交货单过账之后,使用 ABAP 代码来执行后续的业务逻辑,比如发送通知邮件或者更新其他业务对象的数据。 希望这些内容能帮助到您。如果您有其他问题,请随时告诉我。 ### 回答2: ABAP交货单过账的增强点是指在交货单过账的过程中,通过ABAP编程进行功能的扩展和增强。主要包括以下几个方面: 首先,可以通过增强点在交货单过账之前进行数据的校验和处理。例如,在过账之前可以增加一些自定义的业务逻辑,对交货单的数据进行检查,确保数据的准确性和完整性。例如,可以检查交货数量、价格、交货日期等信息是否符合业务规则,并进行相应的处理,例如自动调整数量或价格。 其次,可以通过增强点在交货单过账之后进行自定义的后处理。例如,在过账完成后,可以触发自定义逻辑,例如生成相关报表、发送通知、触发其他交接流程等,以满足业务需求。 另外,还可以通过增强点在交货单过账页面上增加自定义的字段或功能。例如,在交货单过账的界面上增加某个字段来输入额外的信息,或者增加某个按钮来进行特定的操作。这样可以根据具体业务需求对交货单过账进行个性化定制,提升用户体验和操作效率。 总之,ABAP交货单过账的增强点提供了一种灵活、自定义的方式,通过编程进行交货单过账功能的扩展和增强,在满足业务需求的同时提升系统的灵活性和用户体验。 ### 回答3: ABAP语言是一种在SAP系统中进行编程和开发的语言。在交货单过账功能中,可以通过使用ABAP语言来进行增强。 ABAP交货单过账的增强点包括以下几个方面: 1. 自定义报表:可以使用ABAP语言编写代码,自定义交货单过账后的报表输出。通过对交货单数据的处理和计算,生成符合业务需求的报表格式,提供更精准和实用的数据展示。 2. 增加校验逻辑:借助ABAP语言的强大功能,可以对交货单的数据进行更严格的校验。例如,可以添加代码来验证交货数量是否超过库存数量,或者检查交货日期是否在有效范围内。通过增加校验逻辑,可以避免输入错误或不合规的交货数据被过账,提高数据的准确性和完整性。 3. 业务流程扩展:通过在交货单过账功能中增加ABAP代码,可以对业务流程进行扩展。例如,在交货单过账后自动触发其他相关的处理逻辑,如更新相应的库存信息或生成相应的财务凭证。这样可以实现整个交货流程的自动化和高效化。 4. 输出界面定制:利用ABAP语言的特性,可以定制交货单过账时的输出界面。可以根据具体业务需求,调整界面布局、添加额外的字段或标签,使界面更加符合用户的习惯和实际操作需求。 总之,使用ABAP语言对交货单过账功能进行增强,可以根据具体需求对报表、校验逻辑、业务流程和界面进行定制和扩展,提高功能的灵活性、效率和用户体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值