✒️ABAP El Batch Input utilizando Call transaction
ABAP El Batch Input utilizando Call transaction
Lección: Batch Input utilizando Call transaction
1) Mi primer Batch input utilizando 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
Como lo que vamos a hacer será la carga inicial de la tabla de usuarios, borraremos su contenido previamente a la ejecución de este ej. Ahora, seguiremos los pasos
Paso 1º: declaración de datos propios del batch input
Declaramos 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
Estructura BDCMSGCOLL : esta estructura estándar del sistema es utilizada para definir la tabla interna que almacenará los mensajes del batch input
Paso 2º: lectura de datos de archivo de entrada
Ejecutamos el método CL GUI FRONTEND SERVICES-GUI UPLOAD para levantar el archivo de entrada con la información para generar el Batch Input
Paso 3º: carga de la tabla BDCDATA
Para cargar la tabla BDCDATA utilizamos la subrutina BDC_FIELD, 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. Ésto lo solucionamos fácilmente, concatenando al nombre del campo el número de fila que le corresponde en la pantalla entre paréntesis
Paso 4º: ejecución de la sentencia Call Transaction
Ahora vamos a ejecutar la sentencia CALL TRANSACTION con la siguiente sintaxis
Veamos en detalle cada una 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
Modo-Efecto
A: procesamiento con la visualización de todas las pantallas. Es el valor default
E: procesamiento donde se muestran las pantallas solo si ocurre un error. Si se alcanza un breakpoint, se termina el procesamiento con SY-SUBRC igual a 1001. El campo SY-MSGTY "S", SY-MSGID contendrá "00" , SY-MSGNO contendrá "344", SY-MSGV1 contendrá "SAPMSSY3" y SY-MSGV2 contendrá el "0131"
N: procesamiento donde no se muestran las pantallas
P: procesamiento donde no se muestran las pantallas. Si se alcanza un breakpoint, se pasa el contro al debugger
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 son:
Update-Efecto
A: actualización asincrónica. La actualización se produce de igual forma a la que sucede si no utilizamos la sentencia COMMIT WORK AND WAIT. Valor por defecto
S: actualización sincrónica. La actualización se produce de igual forma a la que sucede si utilizamos la sentencia COMMIT WORK AND WAIT
L: actualización local
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
Ahora que ya terminamos con todos los pasos del Batch input, vamos 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)
Luego presionamos el botón Entradas nuevas (new entries). 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
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 Aida Cortina Fernandez, en su ámbito de estudios para la Carrera Consultor ABAP.
Aida Cortina Fernandez
Profesión: Consultor Junior - España - Legajo: MK87X
✒️Autor de: 74 Publicaciones Académicas
🎓Cursando Actualmente: Consultor ABAP Nivel Avanzado
🎓Egresado del módulo:
Certificación Académica de Aida Cortina