SAP ABAP interne tabel: creëren, lezen, invullen, kopiëren en verwijderen
Wat is een interne tabel?
INTERNE TABEL worden gebruikt om gegevens uit een vaste structuur te verkrijgen voor dynamisch gebruik in ABAP. Elke regel in de interne tabel heeft dezelfde veldstructuur. Het belangrijkste gebruik van interne tabellen is het opslaan en opmaken van gegevens uit een databasetabel binnen een programma.
Wat is een werkgebied?
Werkgebieden zijn enkele rijen met gegevens. Ze moeten hetzelfde formaat hebben als alle interne tabellen. Het wordt gebruikt om de gegevens in een interne tabel regel voor regel te verwerken.
Verschil tussen interne tafel en een werkgebied?
Een beeld zegt meer dan duizend woorden
Soorten interne tabellen
Er zijn twee soorten interne tabellen.
- Interne tabellen met HEADER-lijn
- Interne tabellen zonder HEADER-regel.
Interne tabellen met kopregel
- Hier creëert het systeem automatisch het werkgebied.
- Het werkgebied heeft hetzelfde gegevenstype als de interne tabel.
- Dit werkgebied wordt de HEADER-lijn genoemd.
- Hier worden alle wijzigingen of enige actie op de inhoud van de tabel uitgevoerd. Als gevolg hiervan kunnen records rechtstreeks in de tabel worden ingevoegd of rechtstreeks vanuit de interne tabel worden geopend.
Interne tabellen zonder kopregel :
- Hier is geen werkgebied aan de tafel gekoppeld.
- Het werkgebied moet expliciet worden gespecificeerd wanneer we toegang tot dergelijke tabellen nodig hebben.
- Daarom zijn deze tabellen niet rechtstreeks toegankelijk.
Interne tabellen maken
Er zijn veel manieren om een interne tabel te maken. Laten we ze een voor een bekijken-
1.Door gebruik te maken van de Type-instructie
Laten we nu een interne tabel itab maken met behulp van de TYPE-instructie.
De syntaxis is -
Types : begin of line, column1 type I, column2 type I, end of line.
Voorbeeld:
TYPES : begin of line, empno type I, empname(20) type c , end of line.
De instructie TYPES creëert een structuurlijn zoals gedefinieerd.
Om daadwerkelijk een interne tabel itab te maken, gebruikt u de volgende opdracht:
Data itab type line occurs 10.
Er wordt een interne tabel itab gemaakt met de structuur van line. Naast het declareren van de structuur van een interne tabel, definieert de OCCURS-clausule ook hoeveel tabelitems er in de hoofdopslag worden bijgehouden (in dit geval 10). Extra records worden weggeschreven naar het paginggebied en kunnen de prestaties beïnvloeden
2.Door naar een andere tabel te verwijzen
U kunt een interne tabel maken door naar een bestaande tabel te verwijzen. De bestaande tafel zou een standaard kunnen zijn SAP tabel, een Z-tabel of een andere interne tabel.
Syntaxis-
Data <f> <type> [with header line].
Voorbeeld-
DATA itab TYPE line OCCURS 10 with header line.
Hier wordt een interne tabel itab gemaakt van het type regel met een kopregel. Let op: “met kopregel” is optioneel.
3.Door te verwijzen naar de bestaande structuur
Syntaxis-
Data <f> LIKE <struct> occurs n [with header line].
Voorbeeld-
DATA itab LIKE sline OCCURS 10.
Hier wordt een tabel itab gemaakt met dezelfde structuur als die van sline
4.Door een nieuwe structuur te creëren
Laten we nu een interne tabel maken met een eigen structuur. Hier wordt de tabel gemaakt met een kopregel, bij verstek.
Syntaxis -
Data : Begin of <f> occurs <n>, <component declaration>, ................................., End of <f>.
Voorbeeld -
Data : Begin of itab occurs 10, column1 type I, column2(4) type C, column3 like mara-ernam, End of itab.
Interne tabel itab is gemaakt
Interne tabellen invullen
Nu we met succes enkele interne tabellen hebben gemaakt, gaan we kijken hoe we deze kunnen vullen met enkele records. Er zijn verschillende methoden beschikbaar om tabellen te vullen
1. Gegevens regel voor regel toevoegen
De eerste beschikbare methode is het gebruik van de APPEND-instructie.
Met behulp van de APPEND-instructie kunnen we één regel uit een ander werkgebied aan de interne tabel toevoegen, of we kunnen één initiële regel aan de interne tabel toevoegen.
Syntaxis -
APPEND [<wa> TO / INITIAL LINE TO] <itable>.
Hier werkgebied of de initiële regel wordt toegevoegd aan de interne tabel .
De systeemvariabele SY-TABIX bevat de index van de toegevoegde regel.
Voorbeeld:
Data: Begin of itab occurs 10, col1 type C, col2 type I, end of itab. Append initial line to itab.
Resultaten: ' ' '0'
Initial Lines voegt een lijn toe die is geïnitialiseerd met de juiste waarde voor het type ervan aan de tabel. Hier is col1 een teken en col2 een geheel getal. Vervolgens voegt APPEND de initiële regel een regel toe die is geïnitialiseerd met betrekking tot het gegevenstype van de kolommen, dwz ruimte voor col1 en 0 voor col2.
2. Met behulp van de COLLECT-instructie
COLLECT is een andere vorm van instructie die wordt gebruikt voor het vullen van de interne tabellen. Over het algemeen wordt COLLECT gebruikt bij het invoegen van regels in een interne tabel met een unieke standaardsleutel.
Syntaxis-
COLLECT [<wa> INTO] <itable>.
Bij tabellen met een kopregel wordt de optie INTO weggelaten. Stel dat er al een item is met dezelfde sleutel als degene die u probeert toe te voegen, dan wordt er geen nieuwe regel aan de tabel toegevoegd, maar worden de numerieke velden van beide items toegevoegd en is er slechts één item dat overeenkomt met de sleutel aanwezig. . De waarde van SY-TABIX wordt gewijzigd in de rij van de oorspronkelijke invoer. Anders werkt COLLECT vergelijkbaar met APPEND en bevat SY-TABIX de index van de verwerkte regel.
3.INSERT-instructie gebruiken
De INSERT-instructie voegt een regel-/werkgebied toe aan de interne tabel. U kunt de positie opgeven waarop de nieuwe regel moet worden toegevoegd door de INDEX-clausule te gebruiken met de INSERT-instructie.
Syntaxis
INSERT [<wa> INTO / INITIAL LINE INTO] <itable> [index <idx>].
Hier het werkgebied of INITIAL LINE wordt ingevoegd in de interne tabel bij index .
Interne tabellen kopiëren
De inhoud van een interne tabel kan naar een andere worden gekopieerd met behulp van de APPEND LINES- of INSERT LINES-instructie. Een eenvoudigere manier is om een van de volgende syntaxis te gebruiken.
MOVE <itab1> To <itab2>. OR <itab1> = <itab2>.
Deze kopiëren de inhoud van ITAB1 naar ITAB2. In het geval van interne tabellen met kopregel moeten we [] gebruiken om onderscheid te maken van het werkgebied. Dus om de inhoud van interne tabellen met kopregel te kopiëren, wordt de syntaxis:
itab1[] = itab2[].
Lees interne tabellen
We zijn nu bekend met het maken van interne tabellen en het vullen ervan met gegevens. We zullen nu zien hoe we de gegevens daadwerkelijk gebruiken of de gegevens uit de interne tabellen halen.
1. Gebruik Loop-Endloop
Eén van de manieren om toegang te krijgen tot de interne tabel of deze te lezen is door gebruik te maken van LOOP-ENDLOOP.
Syntaxis
LOOP AT <itable> [INTO <wa>] ................................... ENDLOOP.
Als u hier LOOP AT ITABLE zegt, wordt de interne tabel ITABLE regel voor regel gelezen. U kunt tijdens elk deel van de LOOP-ENDLOOP-structuur toegang krijgen tot de waarden van de kolommen voor die regel. De waarde van de SY-SUBRC is ingesteld op 0, zelfs als er maar één record wordt gelezen.
2. LEZEN gebruiken
De andere methode om de interne tabel te lezen is door de READ-instructie te gebruiken.
Syntaxis-
READ TABLE <itable> [INTO <wa>] INDEX <idx>.
Deze instructie leest de huidige regel of regel zoals gespecificeerd door index . De waarde van SY-TABIX is de index van de gelezen regel. Als een item met de opgegeven index wordt gevonden, wordt SY-SUBRC ingesteld op 0. Als de opgegeven index kleiner is dan 0, treedt er een runtimefout op. Als de opgegeven index de tabelgrootte overschrijdt, wordt SY-SUBRC ingesteld op 4.
Interne tabellen verwijderen
Er zijn veel manieren om regels uit een interne tabel te verwijderen.
1.Lijnen in een lus verwijderen.
Dit is de eenvoudigste manier om regels te verwijderen.
Syntaxis
DELETE <ITABLE>.
Deze verklaring werkt alleen binnen een lus. Het verwijdert de huidige regel. U kunt de regels in een lus voorwaardelijk verwijderen door de WHERE-clausule.
2.Regels verwijderen met behulp van de index.
Dit wordt gebruikt om een regel uit de interne tabel bij een bekende index te verwijderen.
Syntaxis
DELETE <ITABLE> INDEX <IDX>.
De lijn met de index wordt verwijderd. De index van de volgende regel wordt met 1 verlaagd.