Top 10 SD Userexits

David Glessner
Product Requirements Planning
R

 SAP America

What is a Userexit?

 A Userexit is a predefined point in the SAP standard code where the user can write code to influence processing.  Code written in userexits is not overwritten during an upgrade.  A list of most userexits can be found in the IMG. SD -> System Modification -> Userexits This list was significantly improved with Release 3.1G

 Code written in userexits is not supported by SAP.
R

 SAP America

Influencing “New Pricing” R  SAP America . Add New Fields for Pricing 5. Pricing Procedure Userexits 6. Partner for Customer/Material Info Record 8. Pricing Type with “New Pricing” 10. User Screens in Sales Order Processing 3. APPEND Structures 2.TOP 10 SD Userexits 1. Sales Document “Save” Userexits 9. Determining Sales Orders Fields 4. ATP Plant Selection 7.

Number 1: Append Structures 1 Can I add a new field to the sales order?  Release 3.0A APPEND STRUCTURES R  SAP America .

Number 2: User Screens in Sales Order Entry 2 I just added a field to the sales order header. How can I maintain / display it in the sales order?  HEADER  SAPMV45A 8309 This is an include dynpro in SAPMV45A 309  ITEM  SAPMV45A 8459 This is an include dynpro in SAPMV45A 459 R  SAP America .

0.0.Number 2: User Screens in Sales Order Entry 2 I just added a field to the sales order header. They have their own tabs in Release 4. How can I maintain / display it in the sales order?  User dynpros exist as part of the “additional data” screens at header/item level in 3.  Sales Installation Specific Data Definitions  MV45ATZZ  Sales Installation Specific PBO Modules  MV45AOZZ  Sales Installation Specific PAI Modules  MV45AIZZ R  SAP America .

Number 3: Determining Sales Order Fields 3a I just added a new field to the sales order header. How do I fill it with a value? 3b How can I determine the payment terms different from standard?  MV45AFZZ  Sales Order Header Sales Order Item  Sales Order Schedule Line USEREXIT_MOVE_FIELD_TO_ VBEP USEREXIT_MOVE_FIELD_TO_VBAK   USEREXIT_MOVE_FIELD_TO_VBAP Sales Order Business Data USEREXIT_MOVE_FIELD_TO_  MV45AFZB  VBKD Sales Order Serial Numbers USEREXIT_MOVE_FIELD_TO_VBSN R  SAP America .

Material Master View: Sales Screen 2 R  SAP America .Ship-to Party Information KURGV .Sold-to Party Information KUWEV .Material Master View: Sales Screen 1 MAEPV .Payer Information KUREV .Bill-to Party Information MAAPV .  Common Work Areas KUAGV .Number 3: Determining Sales Order Fields  MV45ATZZ  Use for general data declarations TABLES: YYYY.

VBAK-ZZFIELD = YYYY-ZZFIELD1. ENDIF. IF SVBAK-TABIX = 0. VBKD-ZTERM = YYYY-ZZFIELD2. R  SAP America . 3b FORM USEREXIT_MOVE_FIELD_TO_VBKD.Number 3: Determining Sales Order Fields  MV45AFZZ 3a FORM USEREXIT_MOVE_FIELD_TO_VBAK. ENDIF. IF SVBKD-TABIX = 0.

User header fields for pricing KOMPAZ .Number 4: Add New Fields for Pricing 4 How can I price off of the new field I added to the sales order header?  Add new field to:   KOMKAZ .  Next slide …. R  SAP America .User item fields for pricing  Add to pricing field catalog and create necessary pricing tables. access sequences.

Sales Order USEREXIT_PRICING_PREPARE_TKOMK TKOMK-ZZABC = VBAK-ZZABC.  RV60AFZZ . USEREXIT_PRICING_PREPARE_TKOMP TKOMP-ZZABC = VBAP-ZZABC.  MV45AFZZ .Number 4: Add New Fields for Pricing 4 How can I price off of the new field I added to the sales order header?  Fill value during order entry and billing.Billing Document USEREXIT_PRICING_PREPARE_TKOMK USEREXIT_PRICING_PREPARE_TKOMP R  SAP America .

Number 5: Pricing Procedure Userexits 5 What are all of the formulas. requirements. in the pricing procedure for?  Pricing Procedure Requirement  Access Sequence Requirement  Scale Base Formula  Condition Base Formula  Condition Value Formula R  SAP America . etc.

Number 5: Pricing Procedure Userexits Account determination Output Control Material determination Listing / Exclusion Scale base Condition base Condition base value Structure of group key Requirements Pricing Statistics Formulas Rounding rule VOFM Copying Requirements Sales Orders Deliveries  SAP America Data transfer Sales Activities Texts Billing Documents R .

 In formulas.Sales item communication structure XKOMV .Internal pricing table R  SAP America .Sales header communication structure KOMP .  Formulas are available to calculate values differently from the way they are calculated in the standard system or to set certain values.Number 5: Pricing Procedure Userexits General Notes  Requirements are available to aid performance by eliminating unnecessary accesses to the database.  Important work areas:    KOMK . the field XKWERT always stands for the number being determined.

 CHECK: KOMP-KZNEP NE „X‟. Examples  Requirement „6‟: Only perform the access if condition exclusion is not active.  CHECK: KOMP-MATKL EQ „ABC‟.Number 5: Pricing Procedure Userexits Requirements  Definable at the pricing procedure and access sequence level. R  SAP America .  The requirement routine defines the circumstances under which the access should be made.  New Requirement: Discount is only relevant for items with material group „ABC‟.

30 which is then used to read the scales to determine the appropriate surcharge. If 24.  Scale Base R  SAP America . scale base formula “023” changes XKWERT to 0.30 pallets are ordered. Standard delivered formula “023” is used with condition type KP03 to compute the incremental surcharge for not ordering in full pallets.Number 5: Pricing Procedure Userexits Formulas  Scale Base Formula  This formula alters the value that the system uses to read the scales in the condition record.

If 24.  Condition Base Formula R  SAP America .30 pallets are ordered.Number 5: Pricing Procedure Userexits Formulas  Condition Base Formula  After the condition record has been read and the scale value retrieved. Standard delivered formula “022” is used with condition type KP00 to compute the discount based on full pallets ordered. it is possible to influence the condition basis to which the scale value will be applied. condition base formula “022” changes XKWERT to 24 which is then multiplied by the scale rate.

Number 5: Pricing Procedure Userexits Formulas  Condition Value Formula  After the system has found the correct scale rate from the condition record and the condition basis for the calculation.  Scale Rate 5.% Condition Basis X X 5 CS 1500 USD Condition Value = = 25.USD  It is possible to influence the condition value calculated by the system using the condition value formula. It is also possible to use the formula to do comparisons and set flags.USD per CS 10. R  SAP America .USD 150. the condition value is calculated.

the “pricing ok” flag is used to block the line item.Number 5: Pricing Procedure Userexits Formulas  Condition Value Formula . XKWERT = 0. Based on the result. the condition value should be set to zero. R  SAP America .  Standard formulas “8” and “9” are used with customer expected price to compare the expected value / price with the net value of the sales order item. ENDIF.  IF XXX = YYY.Examples  Under certain circumstances.

Number 6: ATP Plant Selection 6a My primary sourcing plant is determined by zip code and shipping conditions. Can I do this in SAP? 6b How can I automate the selection of plants on the “Other Plants” push button screen?  MV45AFZB  Selection of primary sourcing plant USEREXIT_SOURCE_DETERMINATION  RV03VFZZ  Selection of secondary sourcing plant USEREXIT_PLANT_SELECTION R  SAP America .

Number 6: ATP Plant Selection 6a My primary sourcing plant is determined by zip code and shipping conditions. SELECT SINGLE * FROM ZZSOURCE WHERE ZIPCD EQ KUWEV-PSTLZ AND LPRIO EQ KUWEV-VSBED. 4. 3. Can I do this in SAP?  Define new table (ZZSOURCE) in data dictionary: ZIPCD LPRIO PLNT1 PLNT2  MV45AFZB FORM USEREXIT_SOURCE_DETERMINATION Zip code (full or partial length) Delivery priority Plant 1 Plant 2.  SAP America . R VBAP-WERKS = ZZSOURCE-PLNT1. etc.

Number 6: ATP Plant Selection 6b How can I automate the selection of plants on the “Other Plants” push button?  RV03VFZZ FORM USEREXIT_PLANT_SELECTION SELECT SINGLE * FROM ZZSOURCE WHERE ZIPCD EQ KUWEV-PSTLZ AND LPRIO EQ KUWEV-VSBED. selections). R  SAP America . etc. (Mark SELKZ field in PLANTS internal table for the plant(s) that should be checked or rearrange plants to show secondary. tertiary.

Can I use the ship-to party or some level of the customer hierarchy?  MV45AFZB  USEREXIT_CUST_MATERIAL_READ US_KUNNR = KUWEV-KUNNR (ship-to party) (or read any partner out of the table XVBPA) R  SAP America .Number 7: Partner for Cust/Mat Info Record 7 SAP uses the sold-to party to read the customer/ material info record.

Number 8: Sales Document “Save” Userexits 8a I have some special checks to perform before a sales order can be saved. Where can I specify them? 8b I have some user tables to update when a sales order is saved. Where can I do that?  MV45AFZZ 8a USEREXIT_SAVE_DOCUMENT_PREPARE (Look at Note 64876 if you want to return the user to the transaction.)  MV45AFZZ 8b USEREXIT_SAVE_DOCUMENT R  SAP America .

 Refer to note 24832 for more examples.Number 9: Pricing Type with New Pricing 9 When I use “new pricing” in the sales order.  Release 4.0C allows the pricing rule to be specified in a pop up window with “New Pricing”. Can I do anything about this?  MV61AFZA  USEREXIT_CHANGE_PRICING_RULE PRICING_RULE = „C‟. I lose all manually entered conditions. R  SAP America .

ENDIF. How can I accomplish this?  MV45AFZB  USEREXIT_NEW_PRICING_VBAP (document item) Example: New pricing if the “route” is changed.Number 10: Influencing “New Pricing” 10 When I change the value of field XXX. the system does not automatically reprice the document.  USEREXIT_NEW_PRICING_VBKD (business data) R  SAP America . IF VBAP-ROUTE NE *VBAP-ROUTE. NEW_PRICING = 'B'.

Sign up to vote on this title
UsefulNot useful