User Exits in SAP Sales Document Processing
User Exits in SAP Sales Document Processing
process without affecting the standard SAP programs. SAP user exits are usually declared as
a form routine.
A user exit is a three character code that instructs the system to access a program during
system processing.
SXX: S is for standard exits that are delivered by SAP. XX represents the 2-digit exit
number.
UXX: U is for user exits that are defined by the user. XX represents the 2-digit exit number
Suppose we want to see the available sales module user exits. Go to transaction SE81. Click
on SD, then click “edit” on the menu bar and choose select subtree. Click on “information
system,” Open Environment node, customer exits, and enhancements. Press F8 to get all the
user exits for that module.
The problem lies in finding the correct userexit and how to find it if one exists for the
purpose. Once the correct userexit is found the necessary customer code is inserted in the
customer include starting with the z.. in the form routine.
e.g. USEREXIT_SAVE_DOCUMENT_PREPARE
Certain application like SD still provide this form of enhancement using userexit but this
practice is no longer being followed for newer extensions instead they are using EXITs which
come bundeled in enhancement packages . Neverthiless existing USEREXITS will be
supported by SAP an all the newer versions of SAP.
HOW TO FIND USEREXITS
Userexits can be found in number of ways:
1) To find userexits in SD module , goto object navigator(SE80) and select development class
from the list and enter VMOD in it. All of the userexits in SD are contained in the
development class VMOD. Press enter and you will find all the includes which contain
userexits in SD for different functions like PRICING, ORDER PROCESSING etc.
Select the userexit according to the requirement and read the comment inserted in it and start
coding .
The fields which are not in either of the two tables KOMK and KOMP cannot be used in
pricing .Sometimes a need arises when the pricing is to be based on some other criteria which
is not present in the form of fields in either of the two tables.
This problem can be solved by using USEREXITS which are provided for pricing in
SD. Pricing takes place both when the SALES ORDER ( Transaction VA01) is created as
well as when INVOICING (Transaction VF01) is done.Hence SAP provides 2 userexits ,one
for sales order processing which is
USEREXIT_PRICING_PREPARE_TKOMP or
USEREXIT_PRICING_PREPARE_TKOMK
Depending upon which table (KOMK or KOMP) the new fields were inserted we use either
of the above two userexits.These userexits are found in include MV45AFZZ of the standard
SAP sales order creation program SAPMV45A.
In the case of userexit which will be called when invoicing is done ,these
are provided in the include RY60AFZZ which is in the standard SAP
program SAPMV45A. The name of the userexits are same. i.e
USEREXIT_PRICING_PREPARE_TKOMP or
USEREXIT_PRICING_PREPARE_TKOMK
These userexits are used for passing the data from the communication structure to the pricing
procedure, for this we have to fill the newely created field in the communication structure
KOMG for this we fill the code in the above userexit using the MOVE statement after the
data that has to be passed is taken from the database table by using the SELECT statement.
The actual structure which is visible in these userexits and which is to be filled for that
particular field is TKOMP or TKOMK.
Before the coding for these userexits is done ,it is necessary to create a new field in either of
the two tables KOMK or KOMP .For this purpose includes are provided in each of them .
To create the field in header data(KOMK) the include provided is KOMKAZ and to create
the field in item data(KOMP) the include provided is KOMPAZ.
One possible example for the need of creating new fields can be e.g. Frieght to be based upon
transportation zone ,for this no field is available in field catalog and hence it can be created in
KOMK and then above userexits can be used to fill the transportation data to it.
2)The other method of finding userexit is to find the word USEREXIT in the associated
program of the transaction for which we want to determine userexit using SE38.
3)The other method of finding userexits is to find the include in case of SD/MM applications
where the userexits are located ,this can be found in the SAP reference IMG generally in the
subfolder under SYSTEM MODIFICATION.
USEREXIT_NUMBER_RANGE
This userexit is used to assign a different internal document number to the sales order(VA01)
when it is created depending on some criteria like a different SALES
ORGANIZAION(VKORG) .
USEREXIT_SAVE_DOCUMENT_PREPARE
This userexit is used to insert the ABAP code which will be called when the document (sales
order VA01) is just about to be saved.This userexit is used generally for custom checks on
different fields , to display some information before the order will be saved or for making
changes to certain fields before the sales order will be saved.
Exits & Enhancements
There are mainly six types of EXITs in sap which have been collected in the form of
enhancement packages and attached to standard code in SAP.
These are different from USEREXIT in the way that they are implemented in the form of
FUNCTIONs while in USEREXITS we use form routines for their implementation. These
are also sometimes known as function exits .
These start from the word EXIT_ followed by the program name and then followed by a three
digit number.
e.g. EXIT_SAPMV45A_002
This exit is found in SD in enhancement V45A0002.
TYPES OF EXITS
1)MENU EXITS
2)FUNCTION EXITS
3)TABLE EXITS
4)SCREEN EXITS
5)KEYWORD EXITS
6)FIELD EXITS
We use SAP transactions CMOD and SMOD to manage exits. Before implementing an exit ,
it is required to create the project by using CMOD selecting the enhancement e.g. V45A0002
and selecting the component (one which fulfills our need) i.e the exit which will be
implemented in SMOD and after coding has been done the project has to be activated.
An exit can be coded only once.
FUNCTION EXITS
These are used to add functionality through ABAP code . These start from the word
EXIT_programname_NNN ending in a 3 digit number. No access code is required to
implement any tupe of exit including function exits.The function exits are called from the
standard SAP program in the form of ABAP statement CALL CUSTOMER-FUNCTION
‘NNN’
This is in contrast to USEREXITs where PERFORM statement is used to call the required
userexit.
To implement the FUNCTION EXITs first of all the project is created and a suitable
enhancement package is selected and from its compnents the function exit to be implemented
is selected and on double clicking it the exit code will appear in ABAP EDITOR(se38) where
a Z include will be found and the customer code should be entered in this include.
Activate the include and Activate the project. Now when ever the SALES ORDER will be
created , sold-to-party field will come up with a predefined customer.
FIELD EXITS
The field exits are managed,created,activated through program RSMODPRF. The field exit is
associated with a data element existing in ABAP dictionary and hence to the screen field
using that data element.
The format of field exit is :
FIELD_EXIT_dataelement_A-Z or 0-9
If a particular screen and program name is not specified than the field exit will effect all the
screens containing that data element.
The function module associated with field exit shows two parameters
INPUT and OUTPUT. Input parameter contains the data passed to the field exit when the
field exit was invoked by the R/3 , We can write our own code to change the output parameter
depending upon our requirements.
Before the field exit can have any effect the system profile parameter
ABAP/FIELDEXIT in all the application servers should be set to YES