Skip to Content

Introduction

Customers often have to change the standard SAP objects in order to meet their own specific requirements. This might involve passing some additional information by adding few extra fields to the standard SAP table. These fields might get updated in underlying Standard SAP tables or customer database table and ultimately serve the business purpose.

Business Scenario

For example, assume that there is extra information that we want to save to the database while creating a new purchase order. I.e. Prepared By, Checked By, Approved By.

5..JPG

BAPI Extension Table

But this change might affect the further BAPI implementations. This is because BAPIs are designed to implement SAP standard business processes through a predefined standard interface. I.e. its import and export parameters for any BAPI are fixed. So addition of new customer fields has absolutely nothing to do with this predefined BAPI interface. This is because these fields are added to SAP database. So executing BAPI with the same import and export parameter is not sufficient. We have to pass extra information about newly added fields. This information is passed to the BAPI using BAPI table extension. The naming convention for BAPI table extensions is BAPI_TE_<table_name>.

Here the customer first creates a data structure that contains the customer-specific fields. In our example, it is CI_EKKODB. This structure is included in both the database table and the BAPI table extension. This ensures that the enhancements to the database table and in the table extension are always identical.

1.JPG

2..JPG

3..JPG

Extension container

Also, an extension parameter (ExtensionIn) in the BAPI interface is used to pass on the enhancements to the BAPI in container format. This extension parameter is always based on data structure BAPIPAREX. Using this parameter BAPI understands the format of the data to be passed.

8..JPG

9.JPG

Here, the STRUCTURE refers to the name of the BAPI table extension though which extra information is to be sent whereas VALUEPART1 to VALUEPART4 are the values that will be inserted in the additional table fields along with the table key field.  Key field, here, purchase_order_no is the extra information that needs to be passed to know the line in the database table where the data record needs to be written.

So extension container could look like

STRUCTURE

VALUEPART1

VALUEPART2

…..

BAPI_TE_MEPOHEADER

3300000180  Nikhil Pravin  Parvati

.

..

Here, ‘3300000180’ is the key field for EKKO table specifying which row to be updated. And “Nikhil Pravin Parvati” is the extra fields of EKKO specified in BAPI_TE_MEPOHEADER.

Source Code

6..JPG

Once the BAPI Extension Table and Extension Container are filled, Execute the BAPI by passing Extension Container as an table type argument.

7..JPG

To report this post you need to login first.

18 Comments

You must be Logged on to comment or reply to a post.

  1. Deepa Tate

    Thank a lot Nikhil.

    Apparently I am struggling with BAPI extension. I read many posts but didn’t get any satisfactory suggestions so far.

    I will go through the document and will revert back asap. πŸ™‚

    (0) 
    1. Nikhil Ghadge Post author

      Thanks Deepa for your feedback.

      Personally, I struggled a lot to learn BAPI with extension. Could not find any good information on internet.

      It was a really good exercise. I thought I should document it.

      Regards,

      NG πŸ™‚

      (0) 
  2. Amit Patil

    Thanx a lot Nikhil…

    i searched a lott for BAPI with extension but didnt got any easy to understand material here..

    Good Job n once again thnx a lottt for such a beautiful presentation of BAPI with extension..

    Keep it up… all the best… πŸ™‚

    (0) 
  3. Manjunath MS

    Hi Nikhil – Very nice explanations & detailed document.  I wanted to know on the logic of routtne “customer_extension”. Where exactly we need to write it. is it on customer enhancement ‘SAPL2012’ – FM “EXIT_SAPL2012_001”.

    (0) 
    1. Nikhil Ghadge Post author

      Hi Manjunath MS

      Scope of this document is only to cover the BAPI extension fields after the customer fields has been added.

      So logic need to be incorporated only when we are calling respective BAPI (FM). So mostly in customized reports in which that BAPI needs to be called.

      For example, you want to write a code to upload Purchase Order data in mass.

      I hope I have answered your query.

      (0) 
  4. LL Quimpo

    Hi Nikhil/All,

    Do you have an idea about using E1BPPAREX in LSMW?

    For example, Object class, investment profile, scale, investment reasonΒ are already existing fields in table COAS but these fields are not in structure E1BP2075_7.

    How can I use the E1BPPAREX to pass the values of the above fields?

     

    Thanks in advance.

    (0) 

Leave a Reply