How to use the performance using Hashed Table?


Hashed table for single read access


Hashed table is used to access the internal table in a constant time. It increase the performance for reading the internal table.


We define select-options for taking input of personnel number.




Next, we define a type ty_payroll based on payroll infotype fields pernr and abrdt. 

A structure and a hashed table based on this type are also defined. 

The hashed table has a unique key pernr.



Similarly, an address type ty_address is defined, along with a structure and internal table.


We then write two select statements. 

The first reads PA0003 for all personnel numbers specified and the date of last payroll run (abrdt). 

The second select statement is used to read all the stras addresses corresponding to permanent
address type (subty = 1) valid at the system date.




Finally, a loop is run on the addresses internal table it_address. 

Within the loop, the read table statement is used for reading the payroll table it_payroll
(the hashed table) for each of the personnel number processed. 

Within the loop, the personnel number, abrdt date, and the address field stras are displayed.

We have used field symbols instead of work areas, in conjunction with loop and read statements for better performance.









How to create Secondary Indexes for Internal Tables?


Introduction to the new concept of secondary keys/index within internal tables.


We first declare a type ty_vbak based on the database table vbak. 

We create two keys for this table type. 

The first is a non-unique primary key having vbeln as the key field. 

We also create a non-unique sorted secondary key sec_key having one field aufnr. 

An internal table it_vbak is defined based on the type ty_vbak. 

In addition, a work area wa_vbak is declared for the table it_vbak.

 It is always better in terms of performance to use field symbols rather than work areas. 

In this example, for simplicity's sake and since the performance gain is minimal, work areas have

been used.



Next, all records from table vbak are read into table it_vbak.


Then, the read table statement is used to read the row of internal table it_vbak pertaining to aufnr 

503002 using the secondary key sec_key.


In the table type definition, we specified a non-unique sorted secondary key (based on aufnr)

along with the primary key. 

For the read statement, we also specify that the secondary key sec_key is to be used when searching in internal table it_vbak the row corresponding to aufnr 503002. 


Since the secondary key is used, the aufnr field is first searched in the secondary index sec_key. 

A faster binary search is used since it is a sorted index. 

The row number of the actual internal table it_vbak containing the aufnr 503002 field is then
determined. 

Once this number is known, the relevant row is read and values assigned to the structure wa_vbak. 

The vbeln field is then printed. 

Had no secondary index been specified, a sequential search through the internal table it_vbak would have been used, which was very time consuming.