Skip to Content

Changed version of a PO is not getting deleted

Hi Experts,

There is one custom FM changing the purchase order in SRM, it does all the process correctly, however, it does not delete the changed version.

Manual process-

1. A PO is in ordered state and we do change anything in that it creates a changed version. (PO is in Saved status now and it is a change version)

2. After doing the changes, we save the PO and order (auto approval scenario), PO comes in Ordered status and the changed version gets deleted as the Ordered version becomes the only active version of the PO.

Custom FM logic-

1. Update PO with the details using 'BBP_PD_PO_UPDATE' function module

2. Change the PO to Ordered status using 'BBP_PD_PO_STATUS_CHANGE' FM


In the later scenario, the changed version is not deleted, however, in the first scenario , the changed version is deleted.

Please guide me.


Add a comment
10|10000 characters needed characters exceeded

Related questions

1 Answer

  • Best Answer
    Posted on Aug 26, 2015 at 12:05 PM

    I get to know that changed version is not deleted after manual operation but it gets converted to historical version.

    What I would need is -

    1. A way to transfer changes to the active version from changed version.

    2. Convert the changed version to historical version


    Add a comment
    10|10000 characters needed characters exceeded

    • gr_po_class = /sapsrm/cl_pdo_factory_po_adv=>get_instance(


      iv_header_guid = pv_guid "gs_ac_header-guid " Globally Unique identifier

      iv_mode = 'DISPLAY' " Process mode of PDO Object Instance

      iv_process_type = 'ECPO' " Business Transaction Type

      iv_user_id = sy-uname "gs_ac_header-changed_by




      co_message_handler = gr_o_msg_cons " Methods for message handling




      ro_new_po = gr_ro_new_po


      co_message_handler = gr_o_msg_cons " Methods for message handling


      Worked for me (obviously exception handling is vital here). The problem got resolved after using complete_po method of PO PDO interface. This deletes the changed version.


Before answering

You should only submit an answer when you are proposing a solution to the poster's problem. If you want the poster to clarify the question or provide more information, please leave a comment instead, requesting additional details. When answering, please include specifics, such as step-by-step instructions, context for the solution, and links to useful resources. Also, please make sure that you answer complies with our Rules of Engagement.
You must be Logged in to submit an answer.

Up to 10 attachments (including images) can be used with a maximum of 1.0 MB each and 10.5 MB total.