如果增强字段在销售订单抬头(vbak)上,则要将增强字段一并append到如下四个表/结构中:

  1. VBAKKOZ
  2. VBAKKOZX
  3. BAPE_VBAK
  4. BAPE_VBAKX

在行项目(vbap)上:

  1. VBAPKOZ
  2. VBAPKOZX
  3. BAPE_VBAP
  4. BAPE_VBAPX

在运货计划行(VBEP)上:

  1. VBEPKOZ
  2. BEPKOZX
  3. BAPE_VBEP
  4. BAPE_VBEPX

下面介绍如何向bapi中extensionin参数赋值数据,具体代码如

*  接口调用日志
  DATA: LT_LOG TYPE STANDARD TABLE OF ZZT_INFLOG,
        LW_LOG TYPE ZZT_INFLOG.   DATA: ORDER_HEADER_INX LIKE BAPISDH1X,
        SCHEDULE_LINES   LIKE BAPISCHDL  OCCURS 0 WITH HEADER LINE,
        SCHEDULE_LINESX  LIKE BAPISCHDLX OCCURS 0 WITH HEADER LINE,
        ORDER_ITEM_IN    LIKE BAPISDITM  OCCURS 0 WITH HEADER LINE,
        ORDER_ITEM_INX   LIKE BAPISDITMX OCCURS 0 WITH HEADER LINE,
        RETURN           LIKE BAPIRET2   OCCURS 0 WITH HEADER LINE.   DATA: LWA_BAPE_VBAK      TYPE BAPE_VBAK,
        LWA_BAPE_VBAKX     TYPE BAPE_VBAKX,         LWA_BAPE_VBAP      TYPE BAPE_VBAP,
        LWA_BAPE_VBAPX     TYPE BAPE_VBAPX,         LWA_VALUEPART(240),
        LIT_PAREX          LIKE TABLE OF BAPIPAREX   WITH HEADER LINE.   DATA: BEGIN OF IT_TAB OCCURS 0,
          VBELN TYPE VBELN,
          POSNR TYPE POSNR,
          ETENR TYPE ETENR,
          LIFSP TYPE LIFSP_EP,
        END OF IT_TAB.   RANGES: R_VBELN FOR VBAP-VBELN,
          R_POSNR FOR VBAP-POSNR.   IF SALESDOCUMENT IS INITIAL.
    E_STATU = 'E'.
    E_MESS  = '单号为空!'.
    EXIT.
  ENDIF.   CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
    EXPORTING
      INPUT  = SALESDOCUMENT
    IMPORTING
      OUTPUT = SALESDOCUMENT.   CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
    EXPORTING
      INPUT  = SALESPOSNR
    IMPORTING
      OUTPUT = SALESPOSNR.   IF SALESDOCUMENT IS NOT INITIAL.
    R_VBELN-SIGN   = 'I'.
    R_VBELN-OPTION = 'EQ'.
    R_VBELN-LOW    = SALESDOCUMENT.
    APPEND R_VBELN.
  ENDIF.
  IF SALESPOSNR IS NOT INITIAL.
    R_POSNR-SIGN   = 'I'.
    R_POSNR-OPTION = 'EQ'.
    R_POSNR-LOW    = SALESPOSNR.
    APPEND R_POSNR.
  ENDIF. ***获得计划行号
  SELECT VBELN POSNR ETENR LIFSP
    INTO TABLE IT_TAB
    FROM VBEP
   WHERE VBELN IN R_VBELN
     AND POSNR IN R_POSNR
     AND ETENR = '0001'.   IF IT_TAB[] IS INITIAL.
    E_STATU = 'E'.
    E_MESS  = '订单项的计划行数据不存在!'.
    EXIT.
  ENDIF.   ORDER_HEADER_INX-UPDATEFLAG = 'U'.   LOOP AT IT_TAB.
    SCHEDULE_LINES-ITM_NUMBER  = IT_TAB-POSNR.
    SCHEDULE_LINES-SCHED_LINE  = IT_TAB-ETENR.
    SCHEDULE_LINES-REQ_DLV_BL  = REQ_DLV_BL.  " Q1/Q2
    IF REQ_DATE IS NOT INITIAL.
      SCHEDULE_LINES-REQ_DATE    = REQ_DATE .  "原始需求日期
    ENDIF.
    APPEND SCHEDULE_LINES.     SCHEDULE_LINESX-UPDATEFLAG  = 'U'.
    SCHEDULE_LINESX-ITM_NUMBER  = IT_TAB-POSNR.
    SCHEDULE_LINESX-SCHED_LINE  = IT_TAB-ETENR.
    SCHEDULE_LINESX-REQ_DLV_BL  = 'X'.
    IF REQ_DATE IS NOT INITIAL.
      SCHEDULE_LINESX-REQ_DATE    = 'X'.
    ENDIF.
    APPEND SCHEDULE_LINESX. *&-->增强字段
    IF FDATU IS NOT INITIAL OR IM_BHDAT IS NOT INITIAL OR IM_BHTIM IS NOT INITIAL.       CLEAR: LWA_BAPE_VBAP,LIT_PAREX.
      LWA_BAPE_VBAP-VBELN = IT_TAB-VBELN.
      LWA_BAPE_VBAP-POSNR = IT_TAB-POSNR.
      IF FDATU IS NOT INITIAL.
        LWA_BAPE_VBAP-FDATU = FDATU .
      ENDIF.
      IF IM_BHDAT IS NOT INITIAL.
        LWA_BAPE_VBAP-Q1Q2DAT = IM_BHDAT .
      ENDIF.
      IF IM_BHTIM IS NOT INITIAL.
        LWA_BAPE_VBAP-Q1Q2TIM = IM_BHTIM .
      ENDIF.       LIT_PAREX-STRUCTURE = 'BAPE_VBAP'.
      LIT_PAREX+30 = LWA_BAPE_VBAP.
      APPEND LIT_PAREX.       CLEAR: LWA_BAPE_VBAPX,LIT_PAREX.
      LWA_BAPE_VBAPX-VBELN = IT_TAB-VBELN.
      LWA_BAPE_VBAPX-POSNR = IT_TAB-POSNR.
      IF FDATU IS NOT INITIAL.
        LWA_BAPE_VBAPX-FDATU = 'X' .
      ENDIF.
      IF IM_BHDAT IS NOT INITIAL.
        LWA_BAPE_VBAPX-Q1Q2DAT = 'X' .
      ENDIF.
      IF IM_BHTIM IS NOT INITIAL.
        LWA_BAPE_VBAPX-Q1Q2TIM = 'X' .
      ENDIF.       LIT_PAREX-STRUCTURE = 'BAPE_VBAPX'.
      LIT_PAREX+30 = LWA_BAPE_VBAPX.
      APPEND LIT_PAREX.     ENDIF. *&-->日志
    CLEAR: LW_LOG.
    LW_LOG-INTTY     = 'A1'.
    LW_LOG-DIRECT    = '2'.
    LW_LOG-INFTX     = '订单计划行标记,以及备货日期更新'.
    LW_LOG-CAFUN     = 'ZRFC_SO_CHANGE'.   "调用函数
    LW_LOG-IKEY1     = REQ_DLV_BL.
    LW_LOG-IKEY2     = REQ_DATE.
    LW_LOG-IKEY3     = IM_BHDAT.
    LW_LOG-IKEY3     = FDATU.
    CONCATENATE ZAUTL IM_ZXQBL INTO LW_LOG-LOGTX.
    APPEND LW_LOG TO LT_LOG. *&-->行项目
    CLEAR: ORDER_ITEM_IN,ORDER_ITEM_INX.
    ORDER_ITEM_IN-ITM_NUMBER = IT_TAB-POSNR.
    APPEND ORDER_ITEM_IN.
    ORDER_ITEM_INX-ITM_NUMBER = IT_TAB-POSNR.
    ORDER_ITEM_INX-UPDATEFLAG = 'U'.
    APPEND ORDER_ITEM_INX.   ENDLOOP. *&-->增强字段 抬头数据
  IF ZAUTL IS NOT INITIAL OR IM_ZXQBL IS NOT INITIAL.
    CLEAR:LWA_BAPE_VBAK,LWA_BAPE_VBAKX,LWA_VALUEPART.
    LWA_BAPE_VBAK-VBELN = SALESDOCUMENT.     IF ZAUTL IS NOT INITIAL.
      LWA_BAPE_VBAK-ZAUTL = ZAUTL.  "分批标记
    ENDIF.
    IF IM_ZXQBL IS NOT INITIAL.
      LWA_BAPE_VBAK-ZXQBL = IM_ZXQBL.  "保持原始需求标记
    ENDIF.
*    lwa_valuepart         = lwa_bape_vbak.
    LIT_PAREX-STRUCTURE   = 'BAPE_VBAK'.
    LIT_PAREX+30  = LWA_BAPE_VBAK.
    
APPEND LIT_PAREX.      CLEAR:LWA_BAPE_VBAK,LWA_VALUEPART.
    LWA_BAPE_VBAKX
-VBELN = SALESDOCUMENT.      IF ZAUTL IS NOT INITIAL.
      LWA_BAPE_VBAKX
-ZAUTL = 'X'. "分批标记
    
ENDIF.
    
IF IM_ZXQBL IS NOT INITIAL.
      LWA_BAPE_VBAKX
-ZXQBL = 'X'. "保持原始需求标记
    
ENDIF.

*    lwa_valuepart         = lwa_bape_vbakx.
    LIT_PAREX
-STRUCTURE   = 'BAPE_VBAKX'.
    LIT_PAREX+30  
= LWA_BAPE_VBAKX.
    
APPEND LIT_PAREX.      CLEAR:LWA_BAPE_VBAKX,LWA_VALUEPART.    ENDIF.    CALL FUNCTION 'BAPI_SALESORDER_CHANGE'
    
EXPORTING
      SALESDOCUMENT    
= SALESDOCUMENT
      ORDER_HEADER_INX 
= ORDER_HEADER_INX
    
TABLES
      
RETURN           = RETURN
      ORDER_ITEM_IN    
= ORDER_ITEM_IN
      ORDER_ITEM_INX   
= ORDER_ITEM_INX
      SCHEDULE_LINES   
= SCHEDULE_LINES
      SCHEDULE_LINESX  
= SCHEDULE_LINESX
      EXTENSIONIN      
= LIT_PAREX[].    READ TABLE RETURN WITH KEY TYPE = 'E'.
  
IF SY-SUBRC <> 0.
    
CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
      
EXPORTING
        
WAIT = 'X'.     E_STATU  = 'S'.
    E_MESS  
= '更新成功!'.      "保存日期
    
IF LT_LOG[] IS NOT INITIAL.
      
CALL FUNCTION 'ZF_SAVE_LOG'
        
TABLES
          IT_LOG 
= LT_LOG.
      
IF SY-SUBRC EQ 0.
        
COMMIT WORK.
      
ENDIF.
    
ENDIF.    ELSE.
    
CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
    E_STATU 
= 'E'.
    E_MESS  
= RETURN-MESSAGE.
    
CLEAR: LT_LOG[].
  
ENDIF.    CLEAR: SALESDOCUMENT,
         ORDER_HEADER_INX
,
         RETURN[]
,
         SCHEDULE_LINES[]
,
         SCHEDULE_LINESX[]
. ENDFUNCTION.

销售订单增强字段 bapi更新的更多相关文章

  1. SAP销售订单屏幕字段控制隐藏,必输等

    1.T-CODE:shd0 创建变式  , 点击确认按钮后,SAP进入下一个屏幕,然后重复上面的操作,直到所有屏幕已完成设置. 如果后续屏幕不需要设置,可点击“退出并保存”按钮.保存后,进入下图所示页 ...

  2. SAP MM 销售订单库存与普通库存之间相互转换过账后对于EBEWH以及MBEWH表的更新

    SAP MM 销售订单库存与普通库存之间相互转换过账后对于EBEWH以及MBEWH表的更新 1,DEMO数据 物料号:1300009995 工厂:2160 销售订单号/item号:0010097627 ...

  3. 如何用代码填充S/4HANA销售订单行项目的数量字段

    我的任务是用代码生成S/4HANA销售订单(Sales Order)的行项目,并且填充对应的quantity(数量)值. 最开始我用了下面的代码,把quantity的值写入item字段target_q ...

  4. 销售订单、外向交货单、交货 bapi

    转自[http://www.cnblogs.com/elegantok/archive/2009/10/18/1585398.html]***********SALES ORDER INPUT CRE ...

  5. 【ABAP系列】SAP 销售订单的行项目里条件的增强

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP 销售订单的行项目里条件的 ...

  6. 【ABAP系列】SAP VA02修改销售订单的BAPI举例

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP VA02修改销售订单的B ...

  7. SAP四代增强实现:销售订单复制项目文本时不需要显示文本框和回车

    最近接收到一个业务需求,在SAP依据销售订单复制时,如果订单里面的项目有多个文本,系统就会显示复制的文本框处理,让用户选择是否复制,这个就让销售很不舒服,如果有几十个项目,每个项目有几个文本,那就就要 ...

  8. VA01销售订单批导问题解决

    1业务场景 事务代码:VA01创建销售订单,VA02修改销售订单 可以通过BAPI_SALESORDER_CREATEFROMDAT2批量创建 可以通过BAPI_SALESORDER_CHANGE批量 ...

  9. 销售订单(SO)-API-更新销售订单

    更新销售订单和创建销售订单差不多,调用的API相同,只是传入的时候标识不一样:operation := oe_globals.g_opr_update 示例代码如下: PROCEDURE update ...

随机推荐

  1. Working With Push Buttons In Oracle Forms

    Managing push buttons at run time in Oracle Forms is very simple and in this tutorial you will learn ...

  2. 【redis】redis实现API接口调用调用次数的限制

    redis实现API接口调用调用次数的限制 参考地址:https://bbs.csdn.net/topics/391856106?page=1 参考地址:https://www.cnblogs.com ...

  3. 通过a标签(不丢失referrer)打开另一个窗口

    第一页 //这个是显示窗口的方法 function frmshow(arr){ var old; var val =$.trim($("#phone").val()); if (v ...

  4. BFC简析

    一.BOX模型 box是CSS中布局的基本单位,而不同类型的box,会参与不同的Formatting Context(一个决定如何渲染文档的容器),box内的元素会以不同的方式渲染. block-le ...

  5. VueJS自定义全局和局部指令

    除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令. 使用directive自定义全局指令 下面我们注册一个全局指令 v-focus, 该指令的功能是在页面 ...

  6. linq查询去重

    通过自定义扩展方法DistinctBy实现去重 public static IEnumerable<TSource> DistinctBy<TSource, TKey> (th ...

  7. 利用JS最真实的模拟鼠标点击

    为了破解永乐票务登录验证码问题 http://www.228.com.cn/auth/login?logout 当然,打码的过程自然依赖第三方平台,但问题是,哪怕平台给了你需要点击的(相对)坐标.你又 ...

  8. Flex版的2048游戏

    近期2048游戏好像挺火.在公交,吃饭,甚至在路上走路都有人拿着手机在玩,之前我看同事玩,认为非常幼稚,移来移去太无聊了吧 到后面自己也下了.发现确实挺无聊的,也就是在无聊的时候打发无聊的时间,后来就 ...

  9. PHP网站常见安全漏洞 及相应防范措施总结

    一.常见PHP网站安全漏洞 对于PHP的漏洞,目前常见的漏洞有五种.分别是Session文件漏洞.SQL注入漏洞.脚本命令执行漏洞.全局变量漏洞和文件漏洞.这里分别对这些漏洞进行简要的介绍. 1.se ...

  10. easyUI中 datagrid 一列字比较多时,出现省略符号

    当数据比较多为,出现省略符号 <style type="text/css">            .datagrid-cell, .datagrid-cell-gro ...