SAP ABAP BAPI BAPI_PO_CHANGE 修改价格POCOND

DATA:LT_RESULT LIKE TABLE OF TYP_RESULT .
  DATA:LS_RESULT LIKE TYP_RESULT .
  DATA:
LS_RETURN LIKE  BAPIRET2,
LS_POITEM LIKE  BAPIMEPOITEM,
LS_POITEMX  LIKE  BAPIMEPOITEMX ,
  LT_RETURN LIKE   TABLE OF BAPIRET2,
  LT_POITEM LIKE    TABLE OF  BAPIMEPOITEM,
  LT_POITEMX  LIKE    TABLE OF  BAPIMEPOITEMX .
  DATA:
        LT_POCOND LIKE TABLE OF   BAPIMEPOCOND ,
         LS_POCOND LIKE    BAPIMEPOCOND ,
        LT_POCONDX  LIKE TABLE  OF    BAPIMEPOCONDX ,
        LS_POCONDX  LIKE    BAPIMEPOCONDX .
  DATA:LV_MESSA TYPE STRING ,
       LV_ALL_MESSA TYPE STRING .
  DATA:LV_FLAG TYPE CHAR01 .

 CLEAR:LT_POITEMX,LT_POITEM .
    CLEAR:LT_POCOND ,LT_POCONDX .

 CLEAR: LS_POITEM ,LS_POITEMX .
      LS_POITEM-PO_ITEM = GS_RESULT-EBELP.
      LS_POITEM-NET_PRICE =  GS_RESULT-NEWPR * gs_result-menge / gs_result-PEINH.
      APPEND LS_POITEM TO LT_POITEM.
      LS_POITEMX-PO_ITEM = GS_RESULT-EBELP.
      LS_POITEMX-NET_PRICE = 'X'.
      APPEND LS_POITEMX TO LT_POITEMX.

      CLEAR: LS_POCOND,LS_POCONDX .
      LS_POCOND-ITM_NUMBER = GS_RESULT-EBELP ..
      LS_POCOND-COND_TYPE = 'PB00' .
      LS_POCOND-COND_VALUE = GS_RESULT-NEWPR * gs_result-menge / gs_result-PEINH .
      LS_POCOND-CURRENCY  = GS_RESULT-WAERS .
      LS_POCOND-CHANGE_ID = 'U' ." (I -> insert), changed (U -> update), or deleted (D -> delete)
      APPEND LS_POCOND TO LT_POCOND .

      LS_POCONDX-ITM_NUMBER = GS_RESULT-EBELP .
      LS_POCONDX-COND_TYPE = 'X' .
      LS_POCONDX-COND_VALUE = 'X' .
      LS_POCONDX-CURRENCY  =  'X'.
      LS_POCONDX-CHANGE_ID = 'X' ." (I -> insert), changed (U -> update), or deleted (D -> delete)
      APPEND LS_POCONDX TO LT_POCONDX .

CLEAR LV_FLAG .
    CLEAR LV_ALL_MESSA .
    CLEAR LV_MESSA .
    CALL FUNCTION 'BAPI_PO_CHANGE'
      EXPORTING
        PURCHASEORDER                = LS_RESULT-EBELN
*       POHEADER                     =
*       POHEADERX                    =
*       POADDRVENDOR                 =
*       TESTRUN                      =
*       MEMORY_UNCOMPLETE            =
*       MEMORY_COMPLETE              =
*       POEXPIMPHEADER               =
*       POEXPIMPHEADERX              =
*       VERSIONS                     =
*       NO_MESSAGING                 =
*       NO_MESSAGE_REQ               =
*       NO_AUTHORITY                 =
*       NO_PRICE_FROM_PO             =
*       PARK_UNCOMPLETE              =
*       PARK_COMPLETE                =
*     IMPORTING
*       EXPHEADER                    =
*       EXPPOEXPIMPHEADER            =
     TABLES
       RETURN                       = LT_RETURN
*       POITEM                       = LT_POITEM
*       POITEMX                      = LT_POITEMX
*       POADDRDELIVERY               =
*       POSCHEDULE                   =
*       POSCHEDULEX                  =
*       POACCOUNT                    =
*       POACCOUNTPROFITSEGMENT       =
*       POACCOUNTX                   =
*       POCONDHEADER                 =
*       POCONDHEADERX                =
       POCOND                       = LT_POCOND
       POCONDX                      = LT_POCONDX
*       POLIMITS                     =
*       POCONTRACTLIMITS             =
*       POSERVICES                   =
*       POSRVACCESSVALUES            =
*       POSERVICESTEXT               =
*       EXTENSIONIN                  =
*       EXTENSIONOUT                 =
*       POEXPIMPITEM                 =
*       POEXPIMPITEMX                =
*       POTEXTHEADER                 =
*       POTEXTITEM                   =
*       ALLVERSIONS                  =
*       POPARTNER                    =
*       POCOMPONENTS                 =
*       POCOMPONENTSX                =
*       POSHIPPING                   =
*       POSHIPPINGX                  =
*       POSHIPPINGEXP                =
*       POHISTORY                    =
*       POHISTORY_TOTALS             =
*       POCONFIRMATION               =
*       SERIALNUMBER                 =
*       SERIALNUMBERX                =
*       INVPLANHEADER                =
*       INVPLANHEADERX               =
*       INVPLANITEM                  =
*       INVPLANITEMX                 =
*       POHISTORY_MA                 =
              .
    LOOP AT LT_RETURN INTO LS_RETURN WHERE TYPE CA 'EAX' .
      CALL FUNCTION 'MESSAGE_TEXT_BUILD'
        EXPORTING
          MSGID               = LS_RETURN-ID
          MSGNR               = LS_RETURN-TYPE
          MSGV1               = LS_RETURN-MESSAGE_V1
          MSGV2               = LS_RETURN-MESSAGE_V2
          MSGV3               = LS_RETURN-MESSAGE_V3
          MSGV4               = LS_RETURN-MESSAGE_V4
        IMPORTING
          MESSAGE_TEXT_OUTPUT = LV_MESSA.
      CONCATENATE LV_ALL_MESSA LV_MESSA INTO LV_ALL_MESSA SEPARATED BY '/'  .
      LV_FLAG = 'X' .
    ENDLOOP .
    IF LV_FLAG IS INITIAL .
      CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
       EXPORTING
         WAIT          = 'X'
* IMPORTING
*   RETURN        =
                .
      LOOP AT GT_RESULT INTO GS_RESULT WHERE EBELN = LS_RESULT-EBELN AND ZCHECK  = 'X' .
        GS_RESULT-ZFLAG = ICON_GREEN_LIGHT .
        GS_RESULT-MESSAGE = '操作成功' .
        MODIFY GT_RESULT FROM GS_RESULT .
      ENDLOOP .
    ELSE .
      CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'
* IMPORTING
*   RETURN        =
    ENDIF .

### 使用 `BAPI_PO_CHANGE` 修改 SAP 采购订单数量 为了修改 SAP 中的采购订单数量,可以使用 `BAPI_PO_CHANGE` 函数模块。此函数允许更新现有采购订单中的各种属性,包括项目级别的数量字段。 以下是具体实现方法: #### 调用参数设置 在调用 `BAPI_PO_CHANGE` 前需准备输入结构体来指定要更改的具体项及其新值。对于调整数量的操作主要涉及两个表:一个是用于传递采购订单头信息;另一个则是明细条目(`PO_ITEMS`)的信息,在这里定义需要变更的商品编号以及新的订购量[^1]。 ```abap DATA: lt_itemscheds TYPE TABLE OF bapiparex, ls_itemscheds LIKE LINE OF lt_itemscheds. " 设置采购订单号和其他必要条件... CALL FUNCTION 'BAPI_PO_GETDETAIL' EXPORTING purchaseorder = lv_purchase_order_number IMPORTING purchasdocument = wa_purdoc. ``` #### 更新物品详情 针对特定商品行增加或减少其预定数目时,则应构建相应的调度行记录并加入到上述提到的数据集中去。注意每一条这样的记录都代表了一次独立的变化操作,并且必须指明对应的物料序号(Item Number)以便系统能够准确定位待处理的对象[^2]。 ```abap ls_itemscheds-number = '1'. " 物料序列号, 需依据实际情况设定 ls_itemscheds-purchasingvaluefield-name = 'ORDERQUANTITY'. ls_itemscheds-purchasingvaluefield-value = new_quantity. " 新的数量值 APPEND ls_itemscheds TO lt_itemscheds. ``` #### 执行 BAPI 变更请求 最后一步就是实际执行这个事务性的命令了。这通常意味着提交整个交易以保存所做的任何改动至数据库中永久存储起来。如果一切顺利的话,那么所选项目的订货数就会按照预期被刷新成最新的数值。 ```abap CALL FUNCTION 'BAPI_PO_CHANGE' EXPORTING purCHASEORDER = lv_purchase_order_number * OTHER_PARAMETERS... AS NEEDED TABLES poitems = lt_poitems poschedulelines = lt_itemscheds EXCEPTIONS document_not_found = 1 no_change_necessary = 2 error_occurred = 3 others = 99. IF sy-subrc <> 0. " Handle errors here as appropriate ENDIF. ``` 通过以上步骤即可完成利用 `BAPI_PO_CHANGE` 对于已存在采购单内某件货物所需总量做出相应增减的任务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值