|
Back to |
Many SAP transactions require multiple rows of data to be processed at the same time. Examples of these transactions include FB50, F-65, ME21, VA01, CS01, CA01, FB70, and others. For many of these transactions, SAP separates the data into a header section and one or more line item or detail sections. The header section usually contains data that remains constant for the entire transaction such as a date. Each line item section typically contains reiterative data that is entered in a grid-like area of the SAP transaction such as journal entry line items.
TRANSACTION handles complex multiline transactions using the Do…While loop feature. With Do…While loops you can map multiple rows to one transaction by defining the records in the Excel worksheet or Access database as Header section or Line Item sections.
In this example, the data for one record is divided among several rows. For multiline transactions, by default the first ID column of Excel is reserved for the Excel Column ID. The first ID Column stores the row type, which defaults to a value of either H (Header) or D (Detail/Line Item). When you run the transaction, TRANSACTION uploads all data from row type H to the Header section of the SAP transaction, and all data from row type D to the line items specified in the Mapper.
NOTE: We strongly recommend that you observe the following conditions when you use TRANSACTION to upload data using multiple loops.
While recording the transaction, we recommend that you enter more than one line item in the transaction to create a visible pattern of repetition in the Mapper. Notice that the example shows more than one set of journal entry line items.
When you map the details column of nested loop, the details automatically appear in the second and third rows of the Preview. This functionality also applies when you use the Automap or Read from SAP features.
When you upload nested loops, the data in your Excel workbook must be laid out in a certain format. The header and its appropriate line items can be in the same column. Each loop can have a header.
H - Header row
D - multiple line items for loop 1
D
D
D1- multiple line items for loop 2
D1
D1
D2- multiple line items for loop 3
D2
D2
A |
B |
C |
In simpler scripts you can easily see where loops are located. In the Basic tab, select a row, and then click the Advanced Options bar.
The Loop Column check box is selected for the rows mapped within the loop that contain data from records identified as Line Items (details). This setting instructs TRANSACTION to pull data from the Line Item (detail) contained in the Do…While Loop.
NOTE: The Loop Column check box must be checked for at least one of the fields. Otherwise, TRANSACTION script generates a syntax error.
You can copy or cut rows that contain loops and conditions. You must select all parts of the loop or condition to edit it. You cannot paste a construct into a log column.
To create a clearer presentation of data when multiple loops are present in a script, the data from loops can reside on multiple Excel data sheets.
You can assign the join key to any column. Therefore, consider carefully which columns already contain data.
To map multiple loops
The Loop Master Parent sheet is selected by default.
The Loop Master sheet and Header sheet is selected by default. Select the appropriate sheet for the line items. Set the corresponding join key columns for the header and line item sheets. Map the rest of the line items.
When a TXR is published, the published sheet must contain the same sheet names that are in the script.
Loops are retrained mapping can be changed from cell-based to column-based mapping. When the mapping type changes, loops become ID based. For example, B,H,D1 becomes B,D1.
If range-based loops are changed to column-based mapping, and then back to cell-based, all loops will be ID based.
TRANSACTION handles complex multiline transactions using the Do...While Loop feature. The basic principles of using the Do...While Loop with Access as the data source include:
An example of the Header table and the Line Item table is shown below.
When the items table is identified and a join is made, the Line Item table is made available in the Mapper for mapping purposes. Then you can map the Line Items (details) by dragging the Access database field and dropping it on the SAP field.
While recording the transaction, it is recommended to enter more than one line item in the transaction in order to create a visible pattern of repetition in the Mapper. Notice that the example shows more than one set of journal entry line items.
To use the Do While...Loop feature to handle multi-line transactions
You can select a row in the Do...While Loop and click the horizontal Properties bar on the far left to display the Properties slide-in. On the Properties slide-in, the Loop Column check box is marked for the rows mapped within the loop that contain data from records identified as Line Items (details). This setting instructs TRANSACTION to pull data from the Line Item (detail) contained in the Do...While Loop.
NOTE: The Loop Column check box must be checked for at least one of the fields. Otherwise, TRANSACTION script generates a syntax error.
When your task requires more than one Do...While loop to fulfill a business process, the Mapper offers two options for using multiple loops to handle these scenarios:
NOTE: Multiple and nested Do...While loops are not supported when Access is used as the data source.
Multiple Do...While loop: Multiple loops are useful in transactions that have more than one set of multiline items (grids). Each of these sets could potentially have either their own set of Header and Line Items, or they could share a common Header section, but have different Line Items, as shown below.
Nested Do...While loop: Nested loops are useful in transactions that require data to be uploaded into multiline items, which contain embedded line items for each item in the topmost level/outer grid. In this case, there is an outer Do...While Loop that contains a number of Do...While Loop nested within it. For example, if you are uploading data in grid A, which contains grids B and C, with each having data related to each line of A, then use a nested Do…While Loop to accomplish the upload. TRANSACTION supports nested Do...While Loops up to any level.
In this example, there are two outer level loops, namely +Do-While A, H, D and +Do-While A, H, D1. Apart from these, the first loop has a nested loop, +Do-While A, H, D2.
The format of the Excel worksheet used for uploading data is:
Also in this section Setting conditions: IF statements |