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

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.

SAP Senior

Javier Miguel Angel Barcelo

Profesión: Militar - Argentina - Legajo: DQ34X

✒️Autor de: 80 Publicaciones Académicas

🎓Cursando Actualmente: Consultor ABAP Nivel Avanzado

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 SemiSenior

TABLAS INTERNAS: En ABAP las tablas internas hacen la función de los ARRAYS bidimensionales de otros lenguajes de programación. El uso más frecuente de una tabla interna es almacenar en memoria los datos de una tabla de una base de datos durante la ejecución de un programa ABAP. Por lo tanto, las tablas internas son memoria dinámica, es decir, se crean en tiempo de ejecución del programa en la parte de memoria RAM asignada para este propósito, y desaparecen una vez que se ha ejecutado el bloque o programa para el que se habían creado.

Acceder a esta publicación

Creado y Compartido por: Marvin Ernesto Gómez Ayala

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

SAP Expert


En ABAP (Advanced Business Application Programming), las tablas internas son estructuras de datos que permiten almacenar conjuntos de información de manera temporal durante la ejecución de un programa. Estas tablas internas son muy útiles para procesar y manipular datos en la memoria del programa, sin necesidad de acceder a la base de datos de manera directa. Las tablas internas son similares a los arrays o listas en otros lenguajes de programación. Permiten almacenar datos de diferentes tipos, como números, caracteres, fechas, entre otros, y pueden contener múltiples filas de datos. A diferencia de las tablas de la base de datos, las tablas internas solo existen en tiempo de ejecución y no se...

Acceder a esta publicación

Creado y Compartido por: Darling Geraldino

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

SAP Master

Tablas internas si queremos guardar datos en la misma estructura de meoria sin necesidad de acceder continuamente a las bases de datos y poder realizar diversas operaciones con este conjunto, entonces se utilizan las tablas internas. uso tipico tablas internas: 1. para almacenar temporalmente los datos de las bases de datos para un procesamiento futuro. 2. para estructurar y formatear datos que se mostraran como salida de programas 3.para formatear datos para ser utilizados por otros servicios. como se crea una tabla interna se crea con la senticia data:begin of (nombre de la tabla) occurs (nunmero de datos a almacenar) (estructura de campos) end of (nombre de la tabla) llenado de una tabla interna: se utiliza al final la senticia append to...

Acceder a esta publicación

Creado y Compartido por: Oscar Sebastian Caicedo Carlier / Disponibilidad Laboral: PartTime + Carta Presentación

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

SAP Senior

LAS TABLA INTERNAS. Si se quiere guardar una colección de registros de datos de la misma estructura en memoria, sin necesidad de acceder continuamente a la tablas bases de datos y poder realizar diversas operaciones con este conjunto de información, entonces utilizaremos tablas internas. 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. 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...

Acceder a esta publicación

Creado y Compartido por: Juan Alberto Peñalver Alvarez / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Expert


Tablas internas: Es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura. Uso de las tablas internas: Para almacenar temporalmente los datos de las BD para procesamiento futuro. Para estructurar y formatear datos que se mostraran como salida del programa. Para formatear datos para ser utilizados por otros servicios. La cantidad de lineas definidas en las tablas internas con la palabra OCCURS no limitan el tamaño de la tabla sino la cantidad de registros que se guardaran en memoria simultaneamente, por lo general se define con 0 para trabajar con tablas con grandes registros. APPEND TO: Añade un registro a la tabla interna en la ultima posición...

Acceder a esta publicación

Creado y Compartido por: Dairy Alejandra Torrenegra Cera

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

SAP Expert


Tablas internas Es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura. Usos de la tabla interna Almacenar temporalmente los datos de las 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. Declaración de tablas internas: Usando la sintaxis: DATA: BEGIN OF TABLA (Definiendo el tamaño OCCURS)....Campos END OF TABLA Usando la sintaxis: DATA: TABLA TYPE TABLE OF Estructura Usando la sintaxis: DATA: TABLA LIKE STANDARD TABLE OF Estructura WITH HEADER LINE. Operaciones de tablas internas APPEND TO: Añade...

Acceder a esta publicación

Creado y Compartido por: Marvin Raul Lopez Morales / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Master


Tablas Internas (arrays, vectores, listas o colecciones en otros lenguajes de programación) Son objetos de datos que permiten guardar en memoria grandes cantidades de registros de datos con la misma estructura. Pueden tener entre 0-N registros. Existe en memoria solo mientras se ejecuta el programa. Tipos de Tablas Internas ANNY TABLE INDEX TABLE STANDARD TABLE SORTER TABLE HASED TABLE En una Tabla Interna podemos Ordenar SORT Recorrer la table LOOP AT Hacer búsquedas secuenciales READ TABLE Hacer búsquedas binarias BINARY SEARCH Modificar MODIFY Insertar INSERT Borrar DELETE Borrar todo el contenido de la tabla, sin eliminarla REFRESH Inicializar cabecera CLEAR...

Acceder a esta publicación

Creado y Compartido por: Lizeth Lorena Castro Ruiz / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Junior

Tablas Internas las tablas internas se utilizaran cuando se quiere guardar una coleccion estructurada de registros sin necesidad de recurrir continuamente a la base de datos. Asi, se podra realizar operaciones con esta informacion. Las tablas internas se utilizan normalmente para almacenar temporalmente datos de la base de datos. Tambien para estructurar datos, los cuales se mostraran en pantalla. Otro uso, es el formatear datos para que otros servicios lo utilicen. Declaracion de tablas internas La sintaxis para declarar una tabla interna es: DATA: BEGIN OF tabla OCCURS n, DefinicionCampo, ...

Acceder a esta publicación

Creado y Compartido por: Jhonatan Parra

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

SAP Master

UNIDAD 3: DICCIONARIO DE DATOS LECCION 1: TABLAS INTERNAS 1| Que son las tablas internas? Es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura, sin necesidad de acceder continuamente a la base de datos. USOS DE LA TABLAS INTERNAS - Almacenar temporalmente los datos de las bases de datos - Estructurar y formatear datos de salida - Formatear datos para ser utilizados por otros servicios 2| Como se declara una TI la sintaxis es: DATA: BEGIN OF <tabla> OCCURS <n>, <def.campos>, END OF <tabla>. 3| Llenado de una TI Usamos APPEND TO, para añadir un registro en la ultima posición con los valores de la work área que tengamos ...

Acceder a esta publicación

Creado y Compartido por: Hernan Cabezas

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

SAP SemiSenior

Tipo de línea de una tabla interna: Suele ser normalmente una estructura, aunque podría ser cualquier tipo. Cada componente de la estructura es una columna de la tabla interna. El tipo puede ser elemental (c, d, f, i, n, p, t, x) o complejo (incluso otra tabla) 2.3. La clave : La clave identifica cada entrada de una tabla. Hay dos tipos de claves: • clave estándar • clave definida por el usuario. El programador puede decidir si la clave es única (UNIQUE) o no (NONUNIQUE). Si la clave es única no puede haber entradas duplicadas. La clave de las tablas estándar NO puede ser única. La clave de las tablas hashed siempre es única. En todas las tablas con un tipo...

Acceder a esta publicación

Creado y Compartido por: Bladimir Martinez Berrocal / Disponibilidad Laboral: FullTime

 


 

👌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!