✒️ABAP Las tablas internas
ABAP Las tablas internas
Tablas internas:
Son objetos de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura.
Almacena entre 0 y 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á relacionada con los limites especificados en la instalación de SAP.
Una tabla interna existe únicamente en memoria, es decir mientras dura la ejecución del programa ABAP.
En otros lenguajes se conoce como array, vector, lista, colección, etc.
Usos típicos:
Almacenar temporalmente datos de las tablas BD para procesamiento futuro: se selecciona los datos de las tablas de la BD, luego se procesan durante la ejecución del programa y por último se vuelven a impactar en las tablas de la BD.
.Estructura y formatear datos en la salida de un programa: Se usan para realizar la salida de los datos de un programa, que puede ser un listado por la pantalla o un archivo que se genera en el servidor o localmente en el equipo que se ejecute.
Formatear datos para ser usados por otros servicios: Para ser usados por otros servicios del sistema SAP.
¿Como se declara una tabla interna?
Ahora bien 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 nos va a permitir:
Leer el contenido de un registro de la tabla interna.
Recorrer cada registro de una tabla interna.
Agregar registros a una tabla interna.
Modificar el contenido de un registro de una tabla interna.
Un área de trabajo o cabecera de un tabla interna solo puede almacenar un registro de datos.
La forma más eficiente es utilizando TYPES, para declarar un tipo de datos. Luego declaramos la tabla interna del mismo tipo de datos utilizando la sentencia TYPE STANDARD TABLE OF. Luego declaramos la estructura o área de trabajo del mismo tipo de datos usando la sentencia LIKE LINE OF.
Otra forma de declarar tablas internas es utilizando la sentencia OCCURS 0, la estructura o área de trabajo se declara igual que el paso anterior.
De esta manera definimos una tabla interna con n líneas en memoria mas un área de trabajo o cabecera.
La cantidad de líneas definidas en la sentencia OCCURS no limitan el tamaño de la tabla interna sino la cantidad de registros que se almacenaran en memoria simultáneamente.
Por lo general en el parámetro OCCURS se especifica la cantidad 0 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 y luego declarar la tabla interna del tipo de datos de la estructura.
Y una cuarta forma de declarar una tabla interna consiste en declararla del mismo tipo de una tabla de la BD existente en el diccionario ABAP.
Esta forma de declarar una tabla interna tiene sentido si encontramos en el diccionario ABAP una tabla de la BD que tenga exactamente los campos que necesitamos para nuestra tabla interna. Si no es así no se justifica.
Por último existe una forma de declarar una tabla interna o área de trabajo o cabecera de una tabla interna usando la misma tabla interna como cabecera, esto se hace usando la sentencia WITH HEADER LINE.
Esta última forma no es aconsejada por SAP.
¿Como llenar el contenido de una tabla interna?
Existen varias formas de agregar o llenar una tabla interna.
La primera es realizar SELECT a una tabla de la BD de SAP y almacenar en una tabla interna el resultado de la selección.
Otra forma consiste en insertar registros en la tabla interna con la sentencia INSERT.
La última manera consiste en añadir registros en la tabla interna con la sentencia APPEND TO. Al usar esta sentencia va agregando registros al final de la tabla interna.
Siempre hay que inicializar el área de trabajo y se hace con la sentencia CLEAR.
En un debug al mirar una tabla interna en la columna Val. de valores visualizamos Standard Table que hace referencia al tipo de tabla interna y 2x3(68) que significa que la tabla interna tiene 2 registros de datos, cada uno de 3 campos y en total ocupan 68 caracteres.
El ordenamiento de una tabla interna
Se usa la sentencia SORT.
Una tabla interna se puede ordenar por cualquier campo que conforman la tabla interna.
Se tienen dos formas de ordenar ASCENDING y DESCENDING.
Si no se especifica la forma de ordenamiento toma por defecto ASCENDING.
¿Como recorrer una tabla interna?
Para recorrer una tabla interna y procesar registro a registro se usa la sentencia LOOP AT-ENDLLOP.
Ahora bien podemos restringir los registros de la tabla interna con la sentencia WHERE.
Si n o existe ningún registro que cumpla la condición en la adición WHERE, el campo SY-SUBRC será distinto de 0.
Por último a la derecha del WHERE podemos especificar mas de una condición y para ellos vamos a concatenar las condiciones con AND o con OR.
Lectura de una tabla interna:
Para leer un registro en particular de una tabla interna sin necesidad de recorrerla registro a registro usamos la sentencia READ TABLE.
.
Si se encuentra el registro SY-SUBRC contiene 0, caso contrario su valor es distinto de 0.
También podemos colocar condiciones mediante la sentencia WITH KEY.
Para optimizar esta casuística existe lo que se conoce como búsqueda binaria. Que es un algoritmo de búsqueda que encuentra la posición de un valor en una taba 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, so no son iguales, la mitad en la cual el valor no esta es eliminada y la búsqueda continua en la mitad restante, utilizando el mismo procedimiento hasta que se encuentre el valor buscado. Esta forma es mas eficiente que la forma secuencia.
Para implementar la búsqueda binaria en ABAP antes de realizar la lectura se debe ordenar la tabla interna por el campo que deseamos buscar, usando la sentencia SORT y luego si se hace la búsqueda binaria usando la cláusula BINARY SEARCH.
Pero si se quiere leer el dato que se encuentra en una posición particular de la tabla interna usamos la cláusula INDEX.
Modificando una tabla interna:
Se usa la sentencia MODIFY.
Si el registro no existe el SY-SUBRC es diferente de 0.
Podemos insertar registros en una tabla interna y se hace con la sentencia INSERT.
Para borrar registros en una tabla interna se usa la sentencia DELETE. El campo SY-SUBRC retorna diferente de 0 si no encuentra el registro.
Para borrar todos los registros de una tabla interna se usa la sentencia REFRESH.
Para saber cuantos registros tiene una tabla interna se usa la sentencia DESRIBE TABLE.
Existen 5 diferentes tipos de tabla interna en ABAP
ANY TABLE
INDEX TABLE
STANDARD TABLE
SORTED TABLE
HASHED TABLE
 
 
 
Sobre el autor
Publicación académica de Lisimaco Prieto Herrera, en su ámbito de estudios para la Carrera Consultor ABAP.
Lisimaco Prieto Herrera
Profesión: Ingeniero de Sistemas - Colombia - Legajo: DV67X
✒️Autor de: 96 Publicaciones Académicas
🎓Egresado de los módulos:
Presentación:
Ingeniero de sistemas con amplia experiencia en el desarrollo de software para el sistema sap r/3 en lenguaje de programación abap.
Certificación Académica de Lisimaco Prieto