PROMO JULIO en CVOSOFT United States Of America: 💎Calidad, 🔥Bonificaciones, 🥶Precios Congelados y MÁS!

 X 

✒️ABAP Las tablas internas

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.

SAP Master

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

✒️+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!