✒️ABAP Las tablas internas
ABAP Las tablas internas
1. ¿Qué son las tablas internas?
Tablas internas
Son un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura.
Una tabla interna puede almacenar entre cero (0) a n registros de datos.
Al momento de declarar una tabla interna es posible especificar la cantidad de registros que puede almacenar, la verdad es que la cantidad de registros máxima está íntimamente relacionada con los límites especificados en la instalación del sistema SAP.
Una tabla interna existe únicamente en memoria en tiempo de ejecución, es decir, mientras se esta ejecutando un programa ABAP.
Una tabla interna en ABAP, en otros lenguajes de programación se conoce como array, vector, lista, colección, etc.
Los usos típicos que se le da a una tabla interna son:
- Para almacenar temporalmente los datos de las tablas bases de datos para un procesamiento futuro: se seleccionan los datos de las tablas bases de datos, luego se procesan esos registros en el programa y por último se vuelven a impactar los cambios en las tablas de la base de datos.
- Para estructurar y formatear datos que se mostrarán como salida del programa: se utilizan tablas internas para realizar la salida de los datos, la cual puede consistir en un listado de salida por la pantalla o un archivo que se genera en el servidor o localmente en el equipo que lo ejecute.
- Para formatear datos para ser utilizados por otros servicios: en ocasiones vamos a necesitar almacenar registros de datos con determinado formato, los cuales servirán como entrada para que otros servicios del sistema SAP los puedan procesar.
2. ¿Cómo se declara una tabla interna?
Para poder trabajar con una tabla interna vamos a necesitar contar con una estructura, también llamada área de trabajo o cabecera de la tabla interna, la cual tendrá el mismo formato que la tabla interna y que nos va a permitir:
- Leer el contenido de un registro de la tabla interna.
- Recorrer cada registro de la tabla interna
- Agregar registros a una tabla interna.
- Modificar el contenido de un registro de la tabla interna.
Una estructura o área de trabajo o cabecera de una tabla interna solo puede almacenar un (1) registro de datos.
La forma más eficiente de declarar una tabla interna es utilizando TYPES, donde primero declaramos un tipo de datos que será TY_ESTRUCTURA, luego se declara la tabla interna TI_ESTRUCTURA de ese mismo tipo de datos utilizando la sentencia TYPE STANDARD TABLE OF. Por último se declara la estructura o área de trabajo WA_ESTRUCTURA que nos va a permitir trabajar con la tabla interna y para ello se utiliza la sentencia LIKE LINE OF.
Una segunda forma que se tiene disponible para declarar la tabla interna TI_ESTRUCTURA es utilizando la sentencia OCCURS 0 y para declarar la estructura o área de trabajo WA_ESTRUCTURA utilizamos la sentencia LIKE LINE OF.
De esta manera se define una tabla interna con n líneas en memoria más una lÍnea de cabecera área de trabajo.
La cantidad de líneas que se especifican en OCCURS no limitan el tamaño de la tabla interna sino la cantidad de registros que se guardarán en memoria simultáneamente.
En el parámetro OCCURS se especifica la cantidad CERO (0) lo que permite trabajar con tablas internas de gran cantidad de registros.
Una tercera forma de declarar una tabla interna consiste en primero declarar la estructura WA_ESTRUCTURA y luego declarar la tabla interna TI_ESTRUCTURA del mismo tipo de datos que la estructura que se declaró anteriormente.
Una cuarta forma de declarar la tabla interna TI_ESTRUCTURA consiste en declararla del mismo tipo que una tabla base de datos existente en el diccionario de datos ABAP.
Existe una forma de declarar la estructura o área de trabajo o cabecera de una tabla interna usando la misma tabla interna como cabecera.
3. ¿Cómo llenar el contenido de una tabla interna?
La primera manera consiste en realizar un SELECT a una tabla base de datos de SAP y almacenar en la tabla interna el resultado de la selección.
Otra forma consiste en insertar registros en la tabla interna mediante la sentencia INSERT.
La última manera consiste en añadir registro a registro en la tabla interna usando APPEND TO. (se agregan al final de la tabla interna)
Existen 5 diferentes tipos de tablas internas en ABAP:
- ANY TABLE
- INDEX TABLE
- STANDARD TABLE (siempre vamos a utilizar éstas)
- SORTED TABLE
- HASHED TABLE
4. El ordenamiento de una tabla interna
Para ordenar una tabla interna utilizamos la sentencia SORT.
Una tabla interna se puede ordenar por cualquier de los campos que forman parte de la tabla interna.
Básicamente tenemos dos opciones para ordenar, de forma ascendente o de forma descendente.
Si al ejecutar la sentencia SORT no se especifica la forma de ordenamiento ya sea ASCENDING o DESCENDING entonces por defecto el ordenamiento de la tabla interna se hace en forma ascendente.
5. ¿Cómo recorrer una tabla interna?
Para recorrer una tabla interna y procesar registro a registro su contenido utilizaremos la sentencia LOOP-ENDLOOP.
Podemos restringir los registros de la tabla interna que vamos a recorrer, en base a que cumplan con una condición que especificamos utilizando la sentencia WHERE.
Si no existe ningún registro que cumpla con la condición especificada en la adición WHERE, el SY-SUBRC será distinto a cero.
A la sentencia WHERE podemos especificar más de una condición y para ello vamos a concatenar las condiciones con AND o con OR según necesitemos.
6. La Lectura de una tabla interna
Para leer un registro en particular de una tabla interna sin necesidad de recorrerla registro a registro usando la sentencia READ_TABLE.
Si se encuentra el registro buscado entonces el SY-SUBRC será cero, en caso contrario, será distinto de cero.
La sentencia READ TABLE va a leer en forma secuencial cada uno de los registros de la tabla interna hasta encontrar aquel registro que cumpla con la condición que escribamos en WITH KEY.
Para optimizar la lectura secuencial con READ TABLE realizamos una Búsqueda Binaria.
Búsqueda Binaria
Es un algoritmo de búsqueda que encuentra la posición de un valor en una tabla interna ordenada, dividiendo el espacio de búsqueda en dos y comparando el valor buscado con el elemento en el medio de la tabla interna, si no son iguales, la mitad en la cual el valor no está es eliminada y la búsqueda continúa en la mitad restante, utilizando el mismo procedimiento hasta que se encuentre el valor buscado.
Esta forma de búsqueda es ampliamente más eficiente que la forma secuencial.
Para implementar la búsqueda binaria en ABAP antes de realizar la lectura debemos primeramente ordenar la tabla interna por el campo que deseamos buscar, usando la sentencia SORT, luego vamos a realizar la lectura usando la clausula BINARY SEARCH.
Si deseamos leer los datos que se encuentran en una posición particular de la tabla interna utilizaremos la cláusula INDEX.
7. Modificando una tabla interna.
Para modificar el contenido de un registro existente en una tabla interna utilizamos la sentencia MODIFY.
Si intentamos modificar un registro de una tabla interna y el mismo no existe entonces el SY-SUBRC será distinto de cero.
Podemos insertar un registro en una posición determinada de una tabla interna utilizando la sentencia INSERT.
Para borrar el contenido de un registro de una tabla interna utilizamos la sentencia DELETE.
Para borrar todo el contenido de una tabla interna utilizamos la sentencia REFRESH.
Si deseamos saber cuántos registros tiene una tabla interna utilizaremos la sentencia DESCRIBE TABLE.
Para inicializar el área de trabajo o cabecera de la tabla interna utilizaremos la sentencia CLEAR.
Para liberar el espacio ocupado por una tabla interna en memoria utilizaremos la sentencia FREE.
 
 
 
Sobre el autor
Publicación académica de Alexis Jesus Perez Ramirez, en su ámbito de estudios para la Carrera Consultor ABAP.
Alexis Jesus Perez Ramirez
Profesión: Licenciado en Computación - Venezuela - Legajo: LK96B
✒️Autor de: 69 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Licenciado en computación egresado de la ucv, con amplia experiencia en base de datos, análisis de sistemas y programación; tanto en ambiente web, cliente/servidor como en computación central.
Certificación Académica de Alexis Perez