✒️ABAP Las tablas internas
ABAP Las tablas internas
Las tablas internas
¿Qué son las 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 O 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.
- Tabla interna (se conoce en otros lenguajes se les conoce como array, vector, lista, colección,etc.
Usos típicos que se le da a una tabla interna.
- 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.
¿Cómo se declara una tabla interna?
- Para poder trabajar con una tabla interna vamos a necesitar contar con una estructura (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 cárea de trabajo o cabecera de una tabla interna solo puede almacenar 1 registro de datos.
- La forma más eficiente de declarar una tabla interna es utilizando TYPES, donde primero por ejemplo, se declara un tipo de datos que será TY_ PROVEEDORES, luego se declara la tabla interna TI_PROVEEDORES de ese mismo tipo de datos utilizando la sentencia TYPE STANDARD TABLE OF. Por último se declara la estructura o área de trabajo WA_PROVEEDORES que nos va a permitir trabajar con la tabla interna y para ello se utiliza la sentencia LIKE LINE OF.
* Declaramos el TYPES
TYPES: BEGIN OF ty_proveedores,
dni (8) TYPE c,
nombre (30) TYPE c,
apellido (30) TYPE c,
END OF ty_proveedores.
* Declaramos la tabla interna y la estructura.
DATA: ti_proveedores TYPE STANDARD TABLE OF ty_proveedores,
wa_proveedores LIKE LINE OF ti_proveedores.
- Una segunda forma que se tiene disponible para declarar la tabla interna TI_PROVEEDORES es utilizando la sentencia Occurs 0 y para declarar la estructura o cárea de trabajo WA_PROVEEDORES utilizamos la sentencia LIKE LINE OF.
* Declaramos la tabla interna
DATA: BEGIN OF ti_proveedores OCCURS 0,
dni (8) TYPE c,
nombre (30) TYPE c,
apellido (30) TYPE c,
END OF ti_ proveedores.
* Declaramos la estructura
DATA: wa_proveedores LIKE LINE OF ti_ proveedores.
- De esta manera se define una tabla interna con un líneas en memoria más una linea de cabeceras á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 O lo que permite trabajar con tablas internas de gran cantidad de registros.
- Al declarar una tabla interna siempre debe ir TI (Tabla interna) y una estructura es WA (Área de trabajo)
- Una tercera forma de declarar una tabla interna consiste en primero declarar la estructura WA_PROVEEDORES y luego declarar la tabla interna TI _PROVEEDORES del mismo tipo de datos que la estructura que se declaró anteriormente.
* Declaramos la estructura
DATA: BEGIN OF wa_proveedores,
dni (8) TYPE c,
nombre (30) TYPE c,
apellido (30) TYPE c,
END OF wa_proveedores.
* Declaramos la tabla interna.
DATA: ti_proveedores LIKE STANDARD TABLE OF wa_proveedores.
- Una cuarta forma de declararla tabla interna TI_PROVEEDORES consiste en declararla del mismo tipo que una tabla base de datos existente en el diccionario de datos ABAP.
* Declaramos la tabla interna y la estructura
DATA: ti_proveedores LI KE TABLE OF Ifal, wa_proveedores LIKE LINE OF Ti_proveedores.
- Existe una forma de declarar la estructura o área de trabajo o cabecera de una tabla interna usando la misma tabla interna como cabecera. Para ello se utiliza la sentencia WITH HEADER LINE (desaconsejada de su uso por SAP)
* Declaramos la tabla interna junto con su cabecera ó área de trabajo
DATA: ti_proveedores LIKE TABLE OF Ifal WITH HEADER LINE.
¿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.
- Insertar registros en la tabla interna mediante la sentencia INSERT.
- Añadir registro a registro en la tabla interna usando APPEND TO. (agregandoalos al final de la tabla interna)
- 5 tipos de tablas: ANY, INDEX, STANDARD, SORT, HASH
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.
- Ordenar de forma ascendente (ASCENDING) o descendente (DESCENDING)
SORT ti_proveedores BY dni DESCENDING.
- Si al ejecutar la sentencia SORT no se especifica la forma de ordenamiento (ascendente o descendente) por defecto el Ordenamiento de la tabla interna se hace en forma ascendente.
¿Cómo recorrer una tabla interna?
- Usando la Sentencia LOOP-ENDLOOP.
* Recorremos la tabla interna.
LOOP AT ti_proveedores INTO wa _proveedores.
WRITE:/ wa_proveedores-dni,
wa _proveedores-nombre.
ENDLOOP.
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.
- 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.
READ TABLE ti_ proveedores INTO wa_proveedores WITH KEY nombre= 'Ariel'.
- Cuando hay demasiados registros para evitar el consumo excesivo de procesamiento se realiza una búsqueda binaria.
- Búsqueda Binaria: 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 continua 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.
- La búsqueda se hace con BINARY SEARCH
- Primero se debe ordenar la tabla interna por el campo que deseas buscar, usando la sentencia SORT, luego realizan la lectura usando BINARY SEARCH.
SORT ti_proveedores ASCENDING BY nombre.
READ TABLE ti_proveedores INTO wa_proveedores WITH KEY nombre= 'Ariel' BINARY SEARCH.
- Si se desea leer los datos que se encuentran en una posición particular de la tabla interna se usa la cláusula INDEX.
READ TABLE ti_ proveedores INTO wa_proveedores INDEX 5.
Modificando una tabla interna.
- Se usa la sentencia MODIFY.
* Modificamos el primer registro de la tabla interna
wa_proveedores-dni = '14544'.
MODIFY ti_ proveedores FROM wa_proveedores INDEX 1.
Si intentamos modificar un registro de una tabla interna y el mismo no existe entonces el SY-SUBRC será distinto de cero.
* Insertamos un registro en la segunda posición de la tabla interna.
wa_proveedores-nombre= 'Ale'.
INSERT wa_proveedores INTO ti _proveedores INDEX 2.
- Para borrar el contenido de un registro de una tabla interna se usa DELETE
DELETE ti_proveedores WHERE dni = '5'.
- Para borrar todo el contenido de una tabla interna se usa la sentencia REFRESH
* Borrar todo el contenido de la tabla Interna
REFRESH ti_proveedores.
- Si se desea saber cuántos registros tiene una tabla interna se usa la sentencia DESCRIBE TABLE.
DESCRIBE TABLE ti_ proveedores LINES v_lineas.
- Inicializar el área de trabajo CLEAR
- Liberar el espacio ocupado poruna tabla interna FREE.
 
 
 
Sobre el autor
Publicación académica de Alejandra Daniela Naranjo Belmonte, en su ámbito de estudios para la Carrera Consultor ABAP.
Alejandra Daniela Naranjo Belmonte
Profesión: Analista/desarrollador de Software - Mexico - Legajo: ON48V
✒️Autor de: 63 Publicaciones Académicas
🎓Egresado del módulo:
Certificación Académica de Alejandra Naranjo