Dynamische Programmierung (ABAP): Unterschied zwischen den Versionen
Aus MattWiki
Matt (Diskussion | Beiträge) Keine Bearbeitungszusammenfassung |
Matt (Diskussion | Beiträge) Keine Bearbeitungszusammenfassung |
||
Zeile 1: | Zeile 1: | ||
Nachfolgend sind verschiedene Ausprädungen dynamischer Programmierung beschrieben. | |||
Die in den Beispielen erstellten internen Tabellen können z.B. mit einem [[ALV-Control_(ABAP)|ALV-Control]] ausgegeben werden. | |||
== Feldsymbole und Datenrefs == | == Feldsymbole und Datenrefs == | ||
=== Dynamisch festgelegte Struktur === | === Dynamisch festgelegte Struktur === | ||
Zeile 47: | Zeile 51: | ||
SELECT * FROM (pa_tab) INTO TABLE <lt_table>. | SELECT * FROM (pa_tab) INTO TABLE <lt_table>. | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Version vom 2. April 2018, 15:13 Uhr
Nachfolgend sind verschiedene Ausprädungen dynamischer Programmierung beschrieben.
Die in den Beispielen erstellten internen Tabellen können z.B. mit einem ALV-Control ausgegeben werden.
Feldsymbole und Datenrefs
Dynamisch festgelegte Struktur
REPORT zmattdynprogwa.
DATA: lv_table_name TYPE string VALUE 'SCARR'.
" Datenreferenz erstellen. Diese kann auf einen typisierten oder
" untypisierten Datenspeicher zeigen. Hier: untypisiert.
DATA: lr_table_line TYPE REF TO data.
" Generisches Feldsymbol ohne initiale Typisierung
FIELD-SYMBOLS: <ls_table_line> TYPE any.
" Reservieren von Hauptspeicher passend zum Typ der Datenreferenz.
CREATE DATA lr_table_line TYPE (lv_table_name).
" Da das Feldsymbol vom Type Any ist, muss im Assign der Zusatz
" Casting Type eingefügt werden, der das Feldsymbol typisiert.
ASSIGN lr_table_line->* TO <ls_table_line> CASTING TYPE (lv_table_name).
" SELECT SINGLE gibt genau eine Zeile für eine Struktur zurück
SELECT SINGLE * FROM (lv_table_name) INTO <ls_table_line>
WHERE mandt = '001' AND carrid = 'BA'.
WRITE <ls_table_line>.
Dynamisch festgelegte interne Tabelle
REPORT zmattdynprogitab.
PARAMETERS: pa_tab TYPE string.
" Untypisierte Datenreferenz
DATA: lr_table TYPE REF TO data.
" Generisches Feldsymbol für interne Tabelle
FIELD-SYMBOLS: <lt_table> TYPE table.
" Reservieren von Hauptspeicher für eine interne
" Tabelle passend zum Typ der Datenreferenz.
CREATE DATA lr_table TYPE TABLE OF (pa_tab).
ASSIGN lr_table->* TO <lt_table>.
SELECT * FROM (pa_tab) INTO TABLE <lt_table>.
RTTS / RTTI / RTTC
RTTS: Runtime Type Services → Bieten Services für RTTI und RTTC
RTTI: Runtime Type Identification → Typen von Variablen zur Laufzeit beschreiben
RTTC: Runtime Type Creation → Typen von Variablen zur Lautzeit erzeugen
Beispiel: