![](/cvo_files/imgs_sap_abap/logos/logo_cvo_academy_it.png)
✒️ABAP Las tablas internas
ABAP Las tablas internas
![ABAP Las tablas internas ABAP Las tablas internas](https://www.cvosoft.com/cvo_files/imgs_sap_abap/og-images/435.jpg)
UNIDAD 3: DICCIONARIO DE DATOS
TEMA 1: TABLA INTERNA
A.- QUE SON LAS TABLAS INTERNAS?
· TABLAS INTERNAS:
>> Son un objeto de datos que permiten guardar en memoria grandes cantidades de registros de datos con la misma estructura.
>> Pueden almacenar entre 0 a n registros de datos.
>> La cantidad de registros máximos de una tabla interna está íntimamente relacionado con los limites específicos en la instalación del sistema SAP.
>> Una tabla interna solo existe mientras se está ejecutando un programa.
· Usos típicos de una tabla interna:
>> PARA ALMACENAR temporalmente los datos de las tablas para un procedimiento futuro:
>>>> Para realizar este procedimiento primero se selecciona los datos, segundo se procesan esos registros en el programa, tercero se vuelven a impactar los cambios en la tabla base de datos.
>> PARA ESTRUCTURAR Y FORMATEAR los datos que se mostraran como salida del programa:
>>>> Se utiliza para realizar las salidas de los datos.
>>>> La salida de datos puede constituir un listado de salida por la pantalla o un archivo.
>> PARA FORMATEAR los datos los cuales van a ser utilizados por otros servicios:
>>>> Va almacenar registros de datos con determinado formato.
>>>> Estos formatos servirán como entrada para que otros servicios del sistema los puedan procesar.
B.- COMO SE DECLARA UNA TABLA INTERNA?
· Va depender según para que lo utilicemos la gran mayoría de las veces.
· Para trabajar con una tabla interna vamos a contar con una estructura.
· Para todo lo que queramos hacer con una tabla interna vamos a necesitar con una estructura del mismo tipo.
· Estructura = Área de trabajo = Cabecera de la tabla interna.
>> La estructura solo puede almacenar 1 registro de datos.
· 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.
· PRIMERA FORMA: Declaración de una tabla interna utilizando TYPES
>> TYPES: Es la forma mas eficiente de declarar una tabla interna.
>> TY_PROVEEDORES: Tipos de datos.
>> TI_PROVEEDORES: Tabla interna.
>> TYPE STANDARD TABLE OF: Es la sentencia.
>> WA_PROVEEDORES: Es la estructura o área de trabajo.
>> LIKE LINE OF: Es la sentencia.
>> Ejemplo:
* 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.
· SEGUNDA FORMA: Declaración de una tabla interna utilizando OCCUS 0.
>> TI_PROVEEDORES: Tabla a declarar.
>> OCCURS 0: Es la sentencia.
>> WA_PROVEEDORES: Es la estructura o Área de trabajo.
>> LIKE LINE OF: Es la sentencia.
>> Ejemplo:
* 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.
>> Así se define una tabla interna con n líneas.
>> La cantidad de líneas que se especifican en OCCURS no limitan el tamaño de la tabla interna.
>>La cantidad de líneas de que se especifica en OCCURS limita la cantidad de registros que se guardan en memoria.
>> En el parámetro OCCURS la cantidad 0 permite trabajar con tablas internas de gran cantidad de registro.
· TERCERA FORMA: Declaración de un tabla interna utilizando una estructura.
>> WA_PROVEEDORES: Es la estructura.
>> TI_PROVEEDORES: Es la tabla interna.
>> Ejemplo:
* 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.
· CUARTA FORMA: Declaración de una tabla interna utilizando una tabla base de datos.
>> Se declara una tabla interna del mismo tipo que una tabla base de datos existente en el diccionario de dato ABAP.
>> TI_PROVEEDORES: Es la tabla interna.
>> Ejemplo:
* Declaramos la tabla interna y la estructura
DATA: ti_proveedores LIKE TABLE OF lfa1,
wa_proveedores LIKE LINE OF ti_proveedores.
>> LFA1: Es la tabla base de datos estándar.
>> En este caso la tabla TI_PROVEEDORES va a tener la misma estructura que la tabla LFA1.
>> JUSTIFICACION PARA DECLARAR ESTA TABLA INTERNA: Se realizara solo si encontramos en el diccionario de datos ABAP una tabla base de datos que tengan los campos que necesitamos para nuestra tabla interna.
· QUINTA FORMA: Declarar una tabla interna con cabecera
>> Se declara la estructura usando la misma tabla interna como cabecera.
>> Se utilizará la sentencia WITH HERADER LINE
>> Ejemplo:
* Declaramos la tabla interna junto con su cabecera o área de trabajo.
DATA: ti_proveedores LIKE TABLE OF lfa1 WITH HEADER LINE.
>> En SAP podemos encontrar en distintas instalaciones del sistema SAP numerosos programas ABAP en donde se declaran cabeceras de tablas internas con la sentencia WITH HEADER LINE.
>> REFLEXION: Es poco recomendable este tipo de declaración.
C.- COMO LLENAR EL CONTENIDO DE UNA TABLA INTERNA?
· Llenar = Es agregar registro a una tabla interna.
· PRIMERA FORMA:
>> 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.
>> SELECT: se puede acceder a los registros almacenado en todas las tablas que componen la base de datos.
· SEGUNDA FORMA:
>> Consiste en insertar registro en la tabla interna.
>> Se utiliza la sentencia INSERT.
· TERCERA FORMA:
>> Consiste en añadir registro a registro en la tabla interna.
>> Se utiliza la sentencia APPEND TO.
>> APPEND TO: Se encarga de agregar un registro añadido al final de la tabla interna.
>> Standard Table: Es un tipo de tabla interna.
>> 2x3(68):
>>>> 2: Son los registros que almacena.
>>>> 3: Son los campos que tiene.
>>>> 68: Son los caracteres que ocupan.
· TIPOS DE TABLAS INTERNAS
>> ANY TABLE:
>>>> Se utiliza para definir el tipo de un parámetro de tabla genérico.
>>>> No se puede usar índices para su acceso.
>>>> Realiza las mismas operaciones que las demás tablas.
>> INDEX TABLE:
>>>> Se puede acceder mediante un índice.
>>>> Los tipos STARNDARD Y SORTED pertenecen al tipo de tabla genérico INDEX TABLE.
>>>> Se puede utilizar para especificar tipo de parámetro genérico en un FORM.
>>>> FORM: Es una subrutina de un programa ABAP.
>> STANDARD TABLE:
>>>> El acceso es mediante una búsqueda lineal.
>>>> Búsqueda Lineal: Significa que el tiempo requerido para la búsqueda está relacionado lineal al número de registro de la tabla.
>> SORTED TABLE:
>>>> Si está bien definida se guardara con el orden correcto.
>>>> El acceso es mediante una búsqueda binaria.
>>>> Búsqueda Binaria:
>>>>>> Tiene dos opciones.
>>>>>> Si la clave no única, el sistema obtiene con el índice más bajo.
>>>>>> El tiempo para el acceso es logarítmicamente relacionado al número de registro de la tabla.
>>>> Otra forma de acceder a SORTED TABLES es mediante operaciones de índices.
>> HA SHED TABLE:
>>>> Es un grupo cuyo elementos pueden acceder usando su única clave.
>>>> Las STANDARD Y SORTED TABLES no se pueden acceder a esas tablas mediante índices.
>>>> Todos los registro deben tener una clave única
>>>> Solo es posible acceder usando las operaciones genéricas de clave o SORT, LOOP.
>>>> No esta permitido las operaciones de índices (LOOP, FROM, INSERT)
D.- EL ORDENAMIENTO DE UNA TABLA INTERNA
· Para ordenar una tabla interna utilizamos la sentencia SORT.
· Opciones disponibles para ordenar:
>> Forma Ascendente: Para especificar utilizaremos la palabra ASCENDING.
>> Forma Descendente: Para especificar utilizaremos la palabra DESCENDING.
E.- COMO RECORRER UNA TABLA INTERNA?
· Utilizaremos la sentencia LOOP-ENDLOOP.
· LOOP-ENDLOOP: Servirá para recorrer una tabla interna y procesar registro a registro su contenido.
· Se puede restringir los registros de la tabla interna que vamos a recorrer.
· Utilizaremos la sentencia WHERE: En base a que cumplan con una condición que se especifique.
· Si no existe ningún registro que cumpla la condición especifica en la adición WHERE, SY-SUBRC será distinto de cero.
F.- LA LECTURA DE UNA TABLA INTERNA
· Se utiliza la sentencia READ TABLE.
· READ TABLE:
>> Se utiliza para leer un registro de una tabla interna.
>> Siempre va a leer de manera secuencial los registros.
>> Si se le asigna una condición, seguirá leyendo de forma secuencial hasta llegar a la condición.
· Para leer una tabla interna se necesita contar con una estructura o área de trabajo.
· Si se encuentra el registro entonces SY-SUBRC será cero.
· Si no se encuentra el registro entonces SY-SUBRC será distinto de cero.
· Búsqueda binaria:
>> Es un algoritmo de búsqueda.
>> Consiste en encontrar la posición de un valor en una tabla interna ordenada.
>> Es binaria porque divide la búsqueda en dos espacios de búsqueda, si la información no es contrada en el primer espacio entonces la elimina. Ahora en la segunda parte la divide en dos y sigue buscando así hasta encontrarlo.
>> Sirve para optimizar el tiempo de búsqueda.
>> Es mas eficiente que la búsqueda secuencial.
· SORT:
>> Es la sentencia que ayuda ordenar la tabla interna.
· INDEX:
>> Es una cláusula que permite leer los datos en una posición particular de la TI.
G.- MODIFICANDO UN TABLA INTERNA
· MODIFY:
>> Se utiliza para modificar el contenido de un registro en un TI.
>> Si modificamos un registro de una TI y este si existe entonces el SY-SUBRC será igual a cero.
>> Si modificamos un registro en una TI y este no existe entonces el SY-SUBRC será distinto de cero.
· INSERT:
>> Es una sentencia que se utiliza para insertar un registro en la TI.
>> Es una sentencia que se utiliza para insertar registro a una TBD.
· DELETE:
>> Es una sentencia que se utiliza para borrar el contenido de un registro de una TI.
>> Es una sentencia que se utiliza para borrar registros de una TBD.
· REFRESH:
>> Es una sentencia que se utiliza para borra los registros completos de una TI.
>> Es una sentencia que se utiliza para inicializar el contenido de una TI.
>> Es exclusivo para tablas internas.
>> Es considera una buena práctica de programación.
>> No confundir con la sentencia CLEAR.
>> CLEAR: Se utiliza para inicializar variables y estructuras.
· DESCRIBE TABLE:
>> Se utiliza para obtener la cantidad de registros que tiene una TI.
>> Es útil dentro de cualquier programa ABAP.
 
 
 
Sobre el autor
Publicación académica de Víctor Alberto Saccaco Maldonado, en su ámbito de estudios para la Carrera Consultor ABAP.
Víctor Alberto Saccaco Maldonado
Profesión: Consultor Abap - Peru - Legajo: RD90F
✒️Autor de: 25 Publicaciones Académicas
🎓Egresado de los módulos:
Disponibilidad Laboral: PartTime
Presentación:
Consultor abap junior, con experiencia en módulos sd, mm.
Certificación Académica de Víctor Saccaco