🚀PROMO #PLANCARRERA2024 - 🔥Bonificaciones, Precios Congelados y Cuotas

 X 

✒️ABAP Las tablas internas

ABAP Las tablas internas

ABAP Las tablas internas

Que son las tablas internas: son un objeto de datos que permite guardar en memoria grande cantidades de registro de datos con la misma estructura. Una tabla interna puede almacenar entre o a n registros de datos. Si bien al momento de declarar una tabla interna es posible especificar la cantindad de registro que puede almacenar, la verdad que la cantidad de registros máxima está intimamente relacionada con los limites especificos en la instalación del sistema SAP.

Una tabla interna exite únicamente en memoria en tiemppo de ejecución es desir mientra se esta ejecutando un programa ABAP.

  • Para almacenar temporalmente los datos de las tablas bases de datos para un procesamiento fururo.
  • Para estructurar y formatear datos que se mostrarán como salida del progama
  • Para formatear datos para ser utilizados por otros servidores

declara una tabla interna:

Dependiendo para que utilizamos la tabla interna nos va a convenir declararlas de una forma u otra.

Ahora bien para poder trabajar con una tabla interna vamos a necesitar contar con una estructura, también llamada área de trabajo o cabecera da la tabla interna, la cual tendrá el mismo formato que la tabla interna y que nos va a permitir :

  • Leer el contenido de registro de la tabla interna.
  • Recorrer cada registro de la tabla interna.
  • Agregar registro a una tabla interna.
  • Modificar el contenido de un registro de la tabla interna.

Básicamente para todo lo que querramos hacer con una tabla interna vamos a necesitar contar con una estructura del mismo tipo.

Una structura o área de trabajo o cabecera de una taba interna solo puede almecenar 1 registro de datos.


Veamos a continuación la siguientes formas que tenemos disponibles para declarar una tabla interna. Para ello la idea es declarar una tabla interna de proveedores cuyos nombre será TI_PROVEERORES con tres campos que son los siguientes:

  1. DNI de tipo caracter de 8 posiciones
  2. NOMBRE de tipo caracter de 30 posiciones
  3. APELLIDO de tipo caracter de 30 posiciones

La forma más eficiente de declarar una tabla interna es utilizando TYPE, 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 utilizado la sentencia TYPE STANDERD 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 OCURS O y para declarar la estructura o área de trabajo WA_PROVEEDORES utilizanos 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 linea de cabecera o área de trabajo. LA cantidad de lineas que se especifican en OCCURS no limita el tamaño de la tabla interna sino la cantidad de registros que se guardarán simultáneamente.

Por lo general, en el parametro OCCURS se especifica la cantidad O lo que permite trabajar con tablas internas de gran cantidad de registro.

Una tercera forma de declar 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 este caso la tabla interna TI_PROVEEDORES tendrán la misma estructura que la tabla base de datos estándar LFA1 del sistema SAP que es el maestro de proveedores, cuya estructura no está formada por los campo DNI, NOMBRE y APELLIDO.

Esta forma de declarar una tabla interma tiene sentido si encontramos en el diccionario de datos ABAP una tabla base de datos que tenga exactamente los campo que nesesitamos para nuestra tabla interna, si no es así entonces no se justefica de ninguna manera crear una tabla bese 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 usamos la sentencia WITH HEADER LINE. (es importante que sepamos de que se trata paro que no la utilicemos en nuestros programas ya que está totalmente desaconsejada su utilización por SAP)

LLenar el contenido de una tabla interna:

existen varias formas de agregar registro a una tabla interna o tambienén llenar una tablabla interna.

La primera consiste en realizar SELECT a uan tabla base de datos de SAP y almacenar en la tabla interna el resultado de la selección.

Otra forma que analizamos más adelante en esta misma lección en insertar registros en la tabla interna mediante la sentencia INSERT.

La última manera consiste en añadir registros a registros en la tabla interna y oara ello vamos a utilizar la sentencia APPEND TO.

Los registros añadidos con APPEND TO se agregan al final de la tabla interna. significa que si la tabla interna esta vacía entonses se ajendará el primer registro de la tabla interna si volvemos a ejecutar entonses el nuevo registro se generara debajo del anteriar y así consecutivamente.

En el ejemplo anterior estamos generando en la tabla interna TI_PROVEEDORES dos registros de datos.

Lo primero que hacemos es limpiar la estructura o área de trabajo WA_PROVEEDORES que vamos a utilizar para hacer el append, para ello ejecutamos la sentencia CLEAR WA_PROVEEDORES.

Luego completamos cada uno de los tres campos de la estructura WA_PROVEEDORES con datos y por último egecutamos la sentencia APPEND TO que impacta en la tabla interna TI_PROVEEDORES con el contenido de la estructura WA_PROVEEDORES, ambas con el mismo tipo de datos. Luego de agregar los dos registros en la tabla interna, el contenido se visualizara en modo debuggin.

Dentro de la columna Val. de valores visualizamos Standard Tabla que hace referencia al tipo de tabla interna y 2x3(68) significa que la tabla interna almacena 2 registros de datos, cada una de los cuales tiene 3 campos y en total ocupan 68 caracteres.

Si hacemos doble clic en TI_PROVEEDORES entonces podemos visualizar el contenido de la tabla interna.

El ordenadoe 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. Básicamente tenemos dos opciones disponibles para ordenar, podemos ordenar de forma ascendiente o de forma descendente.

para ordenar la tabla interna TI_PROVEEDORES por el campo DNI de forma ascendente vamos a a ejecutar:

SORT ti_proveedores BY dni ASCENDING.

para ordenar la tabla interna TI_PROVEEDORES por el campo DNI de forma descendente vamos a a ejecutar:

SORT ti_proveedores BY dni DESCENDING.

Si al ejecutar la sentencia SORT no especificamos la forma de ordenamiento ya sea ASCENDIENG o DESCENDING entonces por defecto el ordenador de la tabla interna se realiza en forma ascendente.

Recorrer una tabla interna:

Para recorrer una tabla interna y procesar registro a registro su contenido utilizamos la sentencia LOOP_ENDLOP.

Para recorrer cada uno de los registros dela tabla interna TI_PROVEEDORES vamos a nesesitar contar con la estructura o área de trabajo WA_PROVEEDPRES.

veamos un Ej:

LOOP AT ti_proveedores INTO wa_proveedores.

WRITE:/ wa_proveedores-dni,

WRITE:/ wa_proveedores-nombre,

WRITE:/ wa_proveedores-apellido.

ENDLOOP.

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 de la siguiente forma:

LOOP AT ti_proveedores INTO wa_proveedores WHERE NOT nombre IS INITIAL.

WRITE:/ wa_proveedores-dni,

WRITE:/ wa_proveedores-nombre,

WRITE:/ wa_proveedores-apellido.

ENDLOOP.

La lectura de una tabla interna:

Para leer un registro en particular de una tabla interna sin nesecidad de recorrela registro a registro utilizamos la sentencia RED TABLE.

Para leer la tabla interna TI_PROVEEDORES vamos a necesitar contra con la estructura o área de trabajo WA_PROVEEDORES.

Si se encuentra el registro buscador entonces el SY-SUBRC será cero, caso contrario, será distinto de cero.

Ahora bien la sentencia RED 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 encoontrar aque registro que cumpla con lacondición que escribamos en WITH KEY.

Búsqueda Binaria: es un algoritmo de busqueda 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 nop 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 procesamiento hasta que se encuentre el valor buscado.

Esta forma de búsqueda es mas eficiente que la forma secuencial.

Para implementar la búsqueda binaria en ABAP antes de realizar la lectura devemos primeramente ordenar la tabla interna por el campo que deseamos buscar, utilizando la sentencia SORT y luego vamos a realizar la lectura utilizando la clausula BINARY SEARCH.

Por último, si deseamos leer los datos que se encuentran en una posición particular de la tabla interna utilizamos la cláusula INDEX .

Modificando una tabla interna:

Para modificar el conteniodo de un registro existentes de una tabla interna utilizamos la sentencia MODIFY.

Para mopdificar la tabla interna TI_PROVEEDORES vamos a necesitar contar con la estructura o área de trabajo WA_PROVEEDORES.

EN el siguiente ejemplo modificamos el campo DNI correspondiente al primer rgistro de la tabla interna TI_PROVEEDORES:

wa_proveedores-dni = '24987500'.

MODIFY ti_proveedores FROM wa_proveedores INDEX 1.

IF sy-subrc EQ 0.

ELSE.

ENDIF.

Si intentamos modificar un registro de una tabla interna y el mismo no existe entonces el SY-SUBRC será distinto a cero.

Podemos insertar un registro en una posición determinada de una tabla interna utilizando la sentencia INSERT.

Para insertar un registro en una tabla interna TI_PROVEEDORES vamos a necesitar contar con la estructura o área de trabajo WA_PROVEEDORES.

En el siguiente ejemplo insertamos un registro en una tabla interna TI_PROVEEDORES en la posición 2.

wa_proveedores-nombre = 'Marcelo'.

wa_proveedores-apellido = 'Rivarola'.

wa_proveedores-dni = '20857492'.

INSERT wa_proveedores INTO ti_proveedores INDEX 2.

IF sy-subrc EQ 0.

ELSE.

ENDIF.

Para borrar el contenido de un registro de una tabla interna utilizamos la sentencia DELETE.

En el siguiente ejemplo borramos todos los registro de la tabla interna TI_PROVEEDORES que culple con la condición DNI igual a 20857492.

DELETE ti_proveedores WHERE dni = '20857492'.

IF sy-subrc EQ 0.

ENDIL.

Para borrar todo el cintenido de una tabla interna utilizamos ls sentencia REFRESH

en el siguiente ejemplo inicilizamoso borramos el cotenido de la tabla interna TI_PROVEEDORES.

REFRESH ti_proveedores.

Y por último, si deseamos saber cuántos registros tiene una tabla interna utilizamos la sentencia DESCRIBE TABLE.

Para ello vamos a necesitar declarar la variable V_LINEAS de tipo I, que va a contener cantidad de registros de la tabla interna TI_PROVEEDORES luego de ejecutar la sentencia DESCRIBE TABLE, lcomo en el siguiente ejemplo:

DATA : v_lineas TYPE i.

DESCRIBE TABLE ti_proveedores LINES v_lineas.

IF v_lineas > 0.

ENDIF.


 

 

 


Sobre el autor

Publicación académica de Javier Miguel Angel Barcelo, en su ámbito de estudios para la Carrera Consultor ABAP.

Javier Miguel Angel Barcelo

Profesión: Militar - Argentina - Legajo: DQ34X

✒️Autor de: 29 Publicaciones Académicas

🎓Cursando Actualmente: Consultor ABAP Nivel Inicial

Certificación Académica de Javier Angel

✒️+Comunidad Académica CVOSOFT

Continúe aprendiendo sobre el tema "Las tablas internas" de la mano de nuestros alumnos.

SAP Senior

El uso de tablas internas facilita y ayuda a que en sap no se generen tablas Z innecesarias.

Acceder a esta publicación

Creado y Compartido por: Faharid Manjarrez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

Para el manejo de tablas internas, es importante saber cuando deben llevar un area de trabajo de tal forma de agilizar y poder explotar la versatilidad del lenguaje de programacion ABAP, porque permita diferenciar el trabajo simple, del trabajo con tablas del sistema.

Acceder a esta publicación

Creado y Compartido por: Luis Enrique Quintero Florido

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

Tabla internas alamcenar temporalmente coleccion de daros sin estar que accediendo a la base de datos para ello utilizamos tablas internas uso tipico almacenar temporalmente los datos de las bases de datos para un procesamiento futuro. estructurar y formatear datos que se mostraran como salida del programa formatear datos para ser utilizados por otros servicios como declarar tablas internas DATA: BEGIN OF <TABLA> OCCURS <N> <DEF CAMPO> END OF <TABLA> OCCURS: especifica la cantidad de registros en memoria AREA DE TRABAJO Cabecera de una tabla interna que tiene el contenido de una tabla interna que se esta procesando APPEND TO : se añade un registro a la tabla interna en la ultima posicion con los valores que...

Acceder a esta publicación

Creado y Compartido por: Andres Felipe Escobar Lopez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

Tablas internas Para acabar (por el momento) tenemos las tablas internas. Sirven básicamente para almacenar la información que extraemos de las tablas de la base de datos. Una tabla interna es también una matriz de datos, pero bidimensional. Al contrario que las estructuras que sólo pueden contener un valor para cada campo, las tablas internas contendrán muchos registros. Cada registro llevará un valor diferente en el mismo campo a la manera que tiene una tabla transparente de diccionario. Podemos declarar tablas internas de diferentes maneras: Ejemplo de declaración de tablas internas: ************************************************************************ *Tablas internas ************************************************************************...

Acceder a esta publicación

Creado y Compartido por: Cesar Ismael Rodriguez Zorrilla

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP SemiSenior

tablas internas. es un objeto de datos. append to

Acceder a esta publicación

Creado y Compartido por: Christian Camilo Alzate Duque

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

TABLAS INTERNAS Objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura. cuyo límite se especifica en la instalacoón del sistema. Usos: Almacenamiento temporal de datos de bases de datos para futuro procesamiento. Estructurar y formatear datos que se mostrarán como salida del programa. Formatear datos para ser utilizados por otrs servicios. DECLARACIÓN DE TABLAS INTERNAS DATA: BEGIN OF <tabla> OCCURS <n>, <Def.Campo>, ... END OF <tabla> Tabla interna es la misma tabla interna estándar DATA: ti_vuelos like standard table of SFLIGHT with header line 3. LLENADO DE TABLA INTERNA Para llenar de datos las tablas internas...

Acceder a esta publicación

Creado y Compartido por: Jorge Alirio Carrillo García

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

- Tablas Internas Las tablas internas son un objeto de datos que nos permite guardar grandes cantidades de registros con la misma estructura, para evitar el acceso a las bases de datos constantemente. La cantidad de registros máxima está limitada a las especificaciones en la instalación del sistema. - Usos de las tablas internas: Almacenar temporalmente los datos de las BD para su procesamiento. Estructurar y formatear datos que se mostrarán como salida del programa. Formatear datos para utilizarlos en otros servicios. - Declaración de una tabla interna: DATA: BEGIN OF <tabla> OCCURS <n>, <Def. Campo>, .... ...

Acceder a esta publicación

Creado y Compartido por: Sandra Erika Bernabe Abreu

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Las tablas internas sirven para realizar operaciones con la data de las tablas estándares sin tener que acceder a estas tablas cada vez que se necesite un dato. El agregado OCCURS en la declaración de una tabla interna limitan la cantidad de registros de la misma. El agregado WITH HEADER LINE define una cabecera a la tabla interna. Se puede declarar una tabla interna de la siguiente manera: <nombre_tabla_1> LIKE STANDARD TABLE OF <work_area>, siendo <work_area> una estructura. CLEAR inicializa una cabecera o work area de una tabla interna. APPEND añade un registro al final de la tabla interna. LOOP - ENDLOOP recorre el contenido de una tabla interna. READ TABLE lee un registro de una tabla interna dada...

Acceder a esta publicación

Creado y Compartido por: George Yunkichi Okuma Zavala

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Tablas Internas Las tablas internas son un objeto de datos que nos permite guardar grandes cantidades de registros con la misma estructura, para evitar el acceso a las bases de datos constantemente. La cantidad de registros máxima está limitada a las especificaciones en la instalación del sistema. - Usos de las tablas internas: Almacenar temporalmente los datos de las BD para su procesamiento. Estructurar y formatear datos que se mostrarán como salida del programa. Formatear datos para utilizarlos en otros servicios. - Declaración de una tabla interna: DATA: BEGIN OF <tabla> OCCURS <n>, <Def. Campo>, .... ...

Acceder a esta publicación

Creado y Compartido por: Juan Rodrigo Meza Avina

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

TABLA INTERNA Es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura. AREA DE TRABAJO: Cabecera de una tabla interna que tiene el contenido del registro de la tabla interna que se esta procesando. OCURRS: Clausula ABAP que se utiliza para especificar la cantidad de registro en memoria de una tabla interna. Por lo general en el parametro OCURRS se especifica la cantidad 0 lo que permite trabajar con tablas de gran cantidad de registros. AREA DE TRABAJO (WA): Cabecera de una tabla interna que tiene el contenido del registro de la tabla interna que se esta procesando. SELECT: Sentencia ABAP que se utiliza para acceder a las bases de datos de SAP. SORT: Sentencia ABAP que se utiliza...

Acceder a esta publicación

Creado y Compartido por: David Camacho Espinoza

 


 

👌Genial!, estos fueron los últimos artículos sobre más de 79.000 publicaciones académicas abiertas, libres y gratuitas compartidas con la comunidad, para acceder a ellas le dejamos el enlace a CVOPEN ACADEMY.

Buscador de Publicaciones:

 


 

No sea Juan... Solo podrá llegar alto si realiza su formación con los mejores!