✒️ABAP El Batch Input utilizando Call transaction
ABAP El Batch Input utilizando Call transaction
Leccion 4/9: Batch Input utilizando Call transaction
1 Mi primer Batch Input utilizando CALL TRANSACTION
Creamos nuestro primer Batch Input utilizando la técnica de CALL TRANSACTION. El objetivo del Batch Input será la carga inicial de datos 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 al campo mandante.
1er PASO. Declaración de datos propios del batch input.
Declarar una tabla interna y una estructura, ambas del tipo BDCDATA, otra tabla interna del tipo BDCMSGCOLL con su estructura, que servirán para almacenar los mensajes que se produzcan cuando ejecutemos el CALL TRANSACTION, 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.
ver código fuente en el texto guía pag 24 img 1.2
NOTA
Estructura BDCMSGCOLL
estructura estándar del sistema utilizada para definir la tabla interna que almacenará los mensajes del batch input.
2do PASO. Lectura de datos de archivo de entrada
Ejecutar el método GUI_UPLOAD para levantar el archivo de entrada con la información para generar el Batch Input.
ver código fuente en el texto guía pag 25 img 1.3
3er PASO Carga de la tabla BDCDATA
Para cargar la tabla BDCDATA utilizar 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 indices para saber en que 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.
ver código fuente en el texto guía pag 26 img 1.4
4to PASO Ejecución de la sentencia Call Transaction
Ejecutar la sentencia CALL TRANSACTION. La sintaxis de la sentencia es la siguiente: ver código fuente en el texto guia pag 26 img 1.5
Funcionalidad de las opciones.
USING: aquí especificamos la tabla BDCDATA que se utilizará.
MODE: determina el modo de procesamiento que utilizará el Batch Input. Los modos posibles de procesamiento son: ver Tabla en el texto guia pag 27 Tabla 1.1
NOTA
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.
UPDATE: determina el modo de actualización de los cambios que producirá el Batch Input. Los modos posibles ver Tabla en el texto guia pag 27 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 BDCMSGCOLL. Para armar los mensajes, vamos a utilizar la función MESSAGE_PREPARE ver Tabla en el texto guia pag 28 Tabla 1.3
Luego que se termina con todos los pasos del Batch Input, se ejecuta 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).
- Se cargan todos los campos del registro y presionamos grabar.
- Finalmente salimos de la transacción y repetiremos esta secuencia de pasos por cuantos registros de usuario ingresemos en la tabla.
NOTA
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.
 
 
 
Sobre el autor
Publicación académica de Ruben Santiago Cuenca Balanza, en su ámbito de estudios para la Carrera Consultor ABAP.
Ruben Santiago Cuenca Balanza
Argentina - Legajo: RU45V
✒️Autor de: 67 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Me presento como una persona activa, responsable, creativa, flexible, orientada al logro de resultados en el trabajo que se me asigne.
Certificación Académica de Ruben Cuenca