✒️ABAP Las tablas internas
ABAP 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 0 a n registros de datos.
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:
-
Para estructurar y formatear datos que se mostrarán como salida del programa
-
Para formatear datos para ser utilizados por otros servicios
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.
Una estructura o área de trabajo o cabecera de una tabla interna solo puede almacenar 1 registro de datos.
La idea es declarar una tabla interna de proveedores que seráTI_PROVEEDORES con tres campos:
-
DNI de tipo caracter de 8 posiciones
NOMBRE de tipo caracter de 30 posiciones -
APELLIDO de tipo caracter de 30 posiciones
La forma más 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 Y por último declaramos la estructura o área de trabajo WA_PROVEEDORES que nos va a permitir trabajar con la tabla interna y para ello utilizamos la sentencia LIKE LINE OF.
Una segunda forma que tenemos disponible para declarar la tabla interna TI_PROVEEDORES 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.
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.
Por lo general, en el parámetro OCCURS se especifica la cantidad 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_PROVEEDORES y luego declarar la tabla interna TI_PROVEEDORES del mismo tipo de datos que la estructura que declaramos anteriormente
Y una cuarta forma de declarar la tabla interna TI_PROVEEDORES consiste en declararla del mismo tipo que una tabla base de datos existente en el diccionario de datos ABAP. En las próximas lecciones de esta unidad veremos bien en detalle qué es el Diccionario de datos ABAP.
Esta forma de declarar una tabla interna tiene sentido si encontramos en el Diccionario de datos ABAP una tabla base de datos que tenga exactamente los campos que necesitamos para nuestra tabla interna, si no es así entonces no se justifica de ninguna manera crear una tabla base de datos en el Diccionario de datos para poder declarar una tabla interna en un programa ABAP
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
no la utilicemos en nuevos programas ya que está totalmente desaconsejada su utilización por SAP.
3 | ¿Cómo llenar el contenido de una tabla interna?Existen varias formas de agregar registros a una tabla interna o lo que también podemos denominar 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 el resultado de la selección. Este tema lo veremos en detalle en las próximas lecciones de esta unidad.
-
Otra forma que analizaremos más adelante en esta misma lección 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 y para ello vamos a utilizar la sentencia APPEND TO.
Los registros que añadimos con APPEND TO se agregan al final de la tabla interna. Esto significa que si la tabla interna se encuentra vacía y realizamos un APPEND TO entonces se generará el primer registro de la tabla interna y si a continuación volvemos a ejecutar un APPEND TO entonces el nuevo registro se generará debajo del anterior y así consecutivamente.
4 | El ordenamiento de una tabla interna
Para ordenar una tabla interna utilizamos la sentencia SORT .
Una tabla interna se puede ordenar por cualquiera de los campos que forman parte de la tabla interna.
Podemos ordenar de forma ascendente o de forma descendente.
Por defecto el ordenamiento de la tabla interna se realiza 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.
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.
Ahora bien podemos restringir los registros de la tabla interna TI_PROVEEDORES que vamos a recorrer, en base a que cumplan con una condición que especifiquemos utilizando la sentencia WHERE
Si no existe ningún registro que cumpla la condición especificada en la adición WHERE, el SY-SUBRC será distinto de cero
Podemos especificar más de una condición, vamos a concatenar las condiciones con AND o con OR.
6 | La lectura de una tabla internaPara leer un registro en particular de una tabla interna sin necesidad de recorrerla 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.
Si se encuentra el registro buscado entonces el SY-SUBRC será cero, caso contrario, será distinto de cero.
Ahora bien la sentencia READ TABLE por más que especifiquemos una condición para la lectura, va a leer en forma secuencial cada uno de los registros de la tabla interna TI_PROVEEDORES hasta encontrar aquel registro que cumpla con la condición que escribamos en WITH KEY.
Imaginemos que tenemos una tabla interna con 500.000 registros de datos y que el registro que buscamos se encuentra en la posición 499.999, si realizamos una lectura secuencial con 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
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, utilizando la sentencia SORT y luego vamos a realizar la lectura utilizando la cláusula BINARY SEARCH
Por último, 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 internaPara modificar el contenido de un registro existente en una tabla interna utilizamos la sentencia MODIFY.
Podemos insertar un registro en una posición determinada de una tabla interna utilizando la sentencia INSERT.
 
 
 
Sobre el autor
Publicación académica de Octavio Ivan Pasciucco, en su ámbito de estudios para la Carrera Consultor ABAP.
Octavio Ivan Pasciucco
Profesión: Consultor Sap Btp - Argentina - Legajo: FX47X
✒️Autor de: 23 Publicaciones Académicas
🎓Cursando Actualmente: Consultor ABAP Nivel Avanzado
🎓Egresado del módulo:
Presentación:
Consultor sap btp
Certificación Académica de Octavio Pasciucco