✒️ABAP El Batch Input utilizando Call transaction
ABAP El Batch Input utilizando Call transaction
Batch Input utilizando Call Transaction
1 Mi primer Batch Input utilizando CALL TRANSACTION
Vamos a crear nuestro primer Batch Input utilizando la técnica del CALL TRANSACTION. El objetivo del Batch Input será la carga inicial de dato de la tabla ZTABLA_USUARIOS.
Para ello, vamos a crear un archivo de texto con registros que cumplan con la estructura de la tabla ZTABLA_USUARIOS, sin tener en cuenta el campo mandante.
<< imagen 1.1 >>
Con este fichero realizaremos al carga inicial de la tabla de usuarios, borraremos su contenido previamente a la ejecución de este ejemplo. Ahora, seguimos los pasos que establecimos en la primera lección de la unidad:
1.- Declaración de datos propios del Batch Input
Declaramos una tabla interna y una estructura, ambas del tipo BDCDATA, y otra tabla interna del tipo BDCMSGCOLL con su estructura que servirán para almacenar los mensajes que se produzcan cuando ejecutemos el CALL TRANSACTION, también la tabla interna de usuarios que contendrá los datos que levantemos del archivo de entrada y una tabla para mostrar por pantalla los errores entre otras declaraciones:
<< imagen 1.2 >>
La estructura estándar BDCMSGCOLL es utilizada para definir la tabla interna que almacenará los mensajes del Batch Input.
2.- Lectura de datos de archivo de entrada
Ejecutamos el método GUI_UPLOAD para cargar el archivo de entrada con la información para generar el Batch Input.
<< imagen 1.3 >>
3.- Carga de la tabla BDCDATA
Para cargar la tabla BDCDATA utilizamos la subrutina BDC_FIELD que vimos en la lección anterior. Antes debemos inicializar la tabla interna del Batch Input y la de los mensajes.
Como vamos a ingresar más de un registro, tendremos que manejar índices para saber en qué fila de la pantalla estamos cargando los datos. Esto lo solucionamos fácilmente concatenando al nombre del campo el número de fila que le corresponde en la pantalla entre paréntesis:
<< imagen 1.4 >>
4.- Ejecución de la sentencia CALL TRANSACTION
A continuación ejecutamos la setencia CALL TRANSACTION. La sintaxis de la sentencia es la siguiente:
<< imagen 1.5 >>
Vemos en detalla las diferentes opciones:
- Using: aquí especificamos la tabla BDCDATA que se utilizará (definida en el paso 1).
- Mode: determina el modo de procesamiento o ejecución que utilizará el Batch Input. Los modos posibles de procesamiento son:
<< Tabla 1.1 >>
Es conveniente utilizar una variable para asignar el modo de procesamiento a un Batch Input. De esta forma podremos modificar su valor dinámicamente durante la ejecución del programa.
Audio: Cuando estamos desarrollando un programa que realiza un Batch Input mediante la técnica de CALL TRANSACTION, es sumamente útil procesar el Batch Input mediante el modo de ejecución "A", el cual nos permite visualizar cada una de las pantallas, ya que en caso de error en los datos que introducimos en la tabla BDCDATA, el procesamiento se detendrá en la pantalla correspondiente al error y será allí donde tendremos que analizar como solucionarlo. Una vez que detectamos y corregimos el error, podemos modificar el modo de ejecución a N.
- Update: determina el modo de actualización de los cambios que producirá el Batch Input. Los modos posibles son:
<< Tabla 1.2 >>
- Messages Into: con el uso de esta opción, todos los mensajes generados durante el procesamiento del Batch Input son almacenados en una tabla interna de tipo BDCMSGCOOL. Para cargar los mensajes, vamos a utilizar la función MESSAGE_PREPARE tal y como vemos a continuación:
<< imagen 1.6 >>
Una vez terminado con todos los pasos del Batch Input, procedemos a ejecutarlo con modo de procesamiento "A", que nos permite ver el paso a paso de las actualizaciones.
Lo primero que hacemos es ingresar a la transacción SM30 con el nombre de la tabla y presionamos el botón Actualizar (Maintain).
<< imagen 1.7 >>
Después pulsamos el botón Entradas Nuevas (New Entries)
<< imagen 1.8 >>
Se cargan todos los campos del regitro y presionamos grabar:
<< imagren 1.9 >>
Finalmente salimos de la transacción y repetiremos esta secuencia de pasos por cuantos registros de usuario ingresemos en la tabla.
<< imagen 1.10 >>
La sentencia CALL TRANSACTION también es muy utilizada en reportes, para acceder a una transacción determinada a partir de los datos presionados en pantalla, con el agregado de la cláusula AND SKIP FIRST SCREEN. Para más información, presionar F1 sobre la sentencia.
 
 
 
Favorito:
Está publicación ha sido agregada a sus favoritos por: Lorena Amoretti
Sobre el autor
Publicación académica de José Antonio Saavedra Rodríguez, en su ámbito de estudios para la Carrera Consultor ABAP.
José Antonio Saavedra Rodríguez
El Salvador - Legajo: SX28V
✒️Autor de: 166 Publicaciones Académicas
🎓Egresado de los módulos:
- Carrera Consultor ABAP Nivel Inicial
- Carrera Consultor en SAP SD Nivel Avanzado
- Carrera Consultor en SAP SD Nivel Inicial