✒️ABAP Las tablas internas
ABAP Las tablas internas
Tabla interna es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura.
En una tabla interna podremos almacenar de 0 a n registros de datos.
Siendo n la cantidad de registros máxima que está relacionada con los límites especificados en la instalación del sistema SAP.
Una tabla interna existe en memoria mientras se esta ejecutando el programa. Luego de ello su contenido se pierde.
Una tabla interna tiene un cuerpo, el cual esta compuesto 1 a n campos, y una cabecera la cual es una estructura que tiene el mismo formato de la tabla interna y se utiliza para acceder a los registros de la tabla interna.
Existen varias formas de declarar tablas internas en ABAP, veamos a continuación algunas de ellas.
Podemos utilizar la adición WITH HEADER LINE para crear en la misma tabla interna la cabecera:
DATA: ti_documentos LIKE TABLE OF dfkkop WITH HEADER LINE.
Otra forma es utilizando la adición OCCURS 0 tal como vemos a continuación:
DATA: BEGIN OF ti_seltab OCCURS 0.
INCLUDE STRUCTURE iseltab.
DATA: END OF ti_seltab.
Otra forma es utilizando TYPES:
TYPES:
BEGIN OF ty_ekko,
ebeln TYPE ebeln,
bukrs TYPE bukrs,
bstyp TYPE ebstyp,
bsart TYPE esart,
aedat TYPE aedat,
ernam TYPE ernam,
lifnr TYPE lifnr,
spras TYPE spras,
zterm TYPE dzterm,
ekorg TYPE ekorg,
ekgrp TYPE ekgrp,
waers TYPE waers,
kdatb TYPE kdatb,
kdate TYPE kdate,
angnr TYPE angnr,
ihran TYPE ihran,
verkf TYPE everk,
inco1 TYPE inco1,
inco2 TYPE inco2,
ktwrt TYPE ktwrt,
frgke TYPE frgke,
knumv TYPE knumv,
lands TYPE land1_stml,
END OF ty_ekko.
DATA: wa_ekko TYPE ty_ekko,
ti_ekko TYPE STANDARD TABLE OF ty_ekko.
OCCURS
La cláusula ABAP OCCURS se utiliza para especificar la cantidad de registro en memoria de una tabla interna.
La sintaxis de la sentencia OCCURS es la siguiente:
DATA : BEGIN OF <Internal table name> OCCURS <n>,
<Field Structure / Line Type>,
END OF < Internal table name >.
Es importante aclarar que <n> no limita el número máximo de registros que pueden almacenarse en una tabla interna.
Por ejemplo si especificamos: OCCURS 10, eso no significa que solo podemos almacenar 10 registros en la tabla interna, sino que ese máximo es limitado teóricamente por la cantidad de memoria disponible en el servidor de aplicaciones.
Estructura APPend - Llenado de una Tabla Interna
Es un objeto ABAP que se crea para agregar datos y configuraciones adicionales a las tablas bases de datos y estructuras estándar de SAP.
Las estructuras append se utilizan para realizar mejoras que no se incluyen en el estándar. Esto incluye desarrollos especiales, versiones de países y agregado de campos de clientes a cualquier tabla o estructura estándar del Diccionario de datos.
SORT - Ordenamiento de una Tabla InternaUtilizamos la sentencia ABAP SORT se utiliza para ordenar una tabla interna.
La sintaxis de la sentencia SORT es la siguiente:
SORT <tabla_interna>.
Junto con la sentencia podemos utilizar una serie de adiciones como por ejemplo:
- ASCENDING: para ordenar en forma ascendente el contenido de la tabla interna Dado que el ordenamiento por default se realiza en forma ascendente no es necesario especificarlo.
- DESCENDING: para ordenar en forma descendente el contenido de la tabla interna.
La palabra reservada del lenguaje ABAP LOOP-ENDLOOP se utiliza para la representación de bucles.
Mediante la sentencia LOOP podremos recorrer registro a registro, el contenido de una tabla interna.
La sintaxis de la sentencia LOOP-ENDLOOP es la siguiente:
LOOP AT <tabla_interna>
...
ENDLOOP.
Existen muchas variantes de la sentencia LOOP-ENDLOOP dependiendo principalmente si existe una cabecera de la tabla interna o no.
Veamos un ejemplo de su utilización:
LOOP AT ti_proveedores INTO wa_proveedores
WHERE NOT nombre IS INITIAL.
ENDLOOP.
READ TABLE - Lectura de una Tabla Interna
Es una sentencia de ABAP que se utiliza para leer un registro de una tabla interna.
La sintaxis de la sentencia READ TABLE es la siguiente:
READ TABLE <tabla_interna>.
Veamos un ejemplo de su utilización:
READ TABLE ti_operaciones INTO wa_operaciones WITH KEY ACTIVITY = '0020'.
Siempre después de la ejecución de la sentencia READ TABLE es necesario preguntar por el contenido de la variable del sistema SY-SUBRC, si es cero entonces la se encontró en la tabla interna el registros que se estaba buscando. Si es distinto de cero entonces no se encontraron datos.
Podemos utilizar la adición BINARY SEARCH al final de la sentencia READ TABLE para realizar un búsqueda binaria en la tabla interna, la cual es sumamente performante en cuestión de rendimiento y tiempos de procesamiento.
Un búsqueda binaria consiste en dividir el espacio de búsqueda en dos y quedarnos con la mitad en donde se encuentra el valor buscado, luego volvemos a dividir el espacio de búsqueda en dos y nos quedamos con la mitad en donde se encuentra el valor buscado y así hasta encontrar el valor buscado.
MODIFY - Modificado de una Tabla Interna
La sentencia ABAP MODIFY que se utiliza para modificar datos, tablas internas o tablas de bases de datos en SAP.
La sintaxis de la sentencia varias dependiendo si lo que se va a actualizar es una tabla base de datos o una tabla interna.
La particularidad que presenta la sentencia MODIFY cuando la utilizamos para modificar tablas bases de datos es que en caso de no existir en la tabla base de datos el registro que se desea modificar entonces el mismo será creado.
 
 
 
Sobre el autor
Publicación académica de Cesar Armando Gutierrez Gomez, en su ámbito de estudios para la Carrera Consultor ABAP.
Cesar Armando Gutierrez Gomez
Profesión: Ingeniero en Sistemas y Redes Infor - El Salvador - Legajo: KQ36J
✒️Autor de: 89 Publicaciones Académicas
🎓Egresado de los módulos:
- Máster Funcional ABAP
- Máster ABAP Orientado a Objetos
- Carrera Consultor ABAP Nivel Avanzado
- Carrera Consultor ABAP Nivel Inicial
Disponibilidad Laboral: FullTime
Certificación Académica de Cesar Gutierrez