✒️ABAP Las tablas internas
ABAP Las tablas internas
Unidad 3: El Diccionario de Datos.
Lección: Las Tablas Internas.
1 - ¿Qué son las tablas internas?
Si queremos guardar una colección de registros de datos de la misma estructura en memoria, sin necesidad de acceder continuamente a las tablas de bases de datos y poder realizar diversas operaciones con este conjunto de información, entonces utilizaremos Tablas Internas.
Tablas Internas: Son objetos de datos que permiten guardar en memoria grandes cantidades de registros de datos con la misma estructura.
Una tabla interna puede almacenar entre 0 y n registros de datos.
Si bien 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 el tiempo de ejecución de un programa.
El mismo concepto que en ABAP se denomina tabla interna, 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 es alguno de los siguientes:
- Para almacenar temporalmente los datos de las tablas bases de datos para un procesamiento futuro: es decir se seleccionan los datos de las tablas bases de datos, luego se procesan esos registros es 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: utilizamos 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 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.
Básicamente para todo lo que queramos hacer con una tabla interna vamos a necesitar contar con una estructura del mismo tipo.
Veamos a continuación las diferentes formas que tenemos disponibles para declarar una tabla interna. Para ello la idea es declarar una tabla interna de proveedores cuyo nombre será TI_PROVEEDORES con tres campos que son los siguientes:
- DNI de tipo carácter de 8 posiciones.
- NOMBRE de tipo carácter de 30 posiciones.
- APELLIDO de tipo carácter de 30 posiciones.
La forma mas eficiente de declarar una tabla interna es utilizando TYPES, en donde primero declaramos un tipo de datos que será TY_PROVEEDORES, luego declaramos la tabla interna TI_PROVEEDORES de ese mismo tipo de datos utilizando la sentencia TYPE STANDARD TABLE OF.
- Siempre que declaramos una tabla interna debemos iniciar el nombre de la misma con TI_nombreTabla
- Siempre que declaramos una estructura o área de trabajo debemos iniciar el nombre de la misma con WA_nombreEstructura.
Una segunda forma que tenemos para declarar una tabla interna es utilizando la sentencia OCCURS 0 y para declarar la estructura o área de trabajo WA_PROVEEDORES utilizamos la sentencia LIKE LINE OF tal como hicimos anteriormente.
De esta manera definimos una tabla interna con n líneas en memoria más una línea de cabecera o área de trabajo.
Una Tercera forma de declarar una tabla interna consiste en primero declarar la estructura WA_PROVEEDORES y luego declara la tabla interna TI_PROVEEDORES del mismo tipo de datos que la estructura declarada anteriormente.
Una Cuarta forma de declarar una tabla interna TI_PROVEEDORES consiste en declararla del mismo tipo que una tabla base de datos existente en el diccionario de datos ABAP.
En este caso la tabla interna TI_PROVEEDORES tendrá la misma estructura que la tabla base de datos estándar LFA1 del sistema SAP que es el Maestro de Proveedores.
Esta forma solo tiene sentido si encontramos una tabla de base de datos que tenga exactamente los campos que necesitamos, caso contrario no se justifica utilizar esta forma.
Por último, 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 utilizamos la sentencia WITH HEADER LINE tal como vemos en la siguiente imagen.
- DATA: ti_proveedores LIKE TABLE OF lfal WITH HEADER LINE.
- Esta manera podemos encontrar en muchos programas ABAP, pero no es recomendable que la utilicemos en nuestros programas.
3 - ¿Cómo llenar el contenido de una tabla interna?
Existen varias maneras de llenar una tabla interna.
La Primera: consiste en realizar un SELECT a una tabla base de datos de SAP y almacenar en la tabla interna los resultados de la selección.
Otra forma consiste en insertar registros en la tabla interna mediante un INSERT.
La última consiste en añadir registro a registro en la tabla interna y para ello vamos a utilizar la sentencia APPEND TO. Estos registros se agregan al final de la tabla interna.
4 - El Ordenamiento de una Tabla Interna.
Para ordenar una tabla interna usamos la sentencia SORT. De forma ascendente o descendente.
Para ordenar la tabla interna TI_PROVEEDORES por el campo DNI de forma ascendente/descendente:
- SORT ti_proveedores BY dni ASCENDING.
5 - ¿Cómo Recorrer una Tabla Interna?
Para recorrer una tabla interna y procesar registro a registro su contenido utilizaremos la sentencia LOOP-ENDLOOP.
Para recorrer cada uno de los registros de la tabla interna TI_PROVEEDORES vamos a necesitar contar con la estructura o área de trabajo WA_PROVEEDORES.
Podemos restringir registros usando WHERE: podemos utilizar todos los filtros que queremos con AND u OR.
6 - La lectura de una Tabla Interna
Para leer un registro en particular de una tabla interna sin necesidad de recorrer registro a registro utilizamos la sentencia READ TABLE.
Para leer la tabla interna TI_PROVEEDORES vamos a necesitar contar con la estructura o área de trabajo WA_PROVEEDORES.
En caso de que encuentre el registro buscado el SY-SUBRC será cero, caso contrario será distinto de cero.
La sentencia READ TABLE por más que especifiquemos una condición de lectura va a leer de forma secuencial todos los registros hasta encontrar aquel que cumpla con la condición que escribamos en WITH KEY.
Imaginemos una tabla interna con 500.000 registros de datos y que el dato que buscamos se encuentra en la posición 499.999, si realizamos una lectura secuencial con el READ TABLE entonces esto implicaría leer 499.999 registros, lo que consume mucho tiempo de procesamiento.
Para optimizar esta casuística existe lo que se conoce como "Búsqueda Binaria".
7 - Modificando una Tabla Interna. MODIFY
Para modificar una tabla interna se utiliza la sentencia MODIFY.
 
 
 
Favorito:
Está publicación ha sido agregada a sus favoritos por: Carlos Piles Rosell
Sobre el autor
Publicación académica de Pedro Antonio Duarte, en su ámbito de estudios para la Carrera Consultor ABAP.
Pedro Antonio Duarte
Profesión: Consultor de Sap Abap - Argentina - Legajo: JP24O
✒️Autor de: 128 Publicaciones Académicas
🎓Egresado de los módulos:
Disponibilidad Laboral: FullTime
Certificación Académica de Pedro Duarte