✒️ABAP El Batch Input utilizando Call transaction
ABAP El Batch Input utilizando Call transaction
Mi primer BatchInput utilizando CALL REANSACTION.
Vamos a crear nuestro primer Batch Input utilizando la tecnica de CALL TRANSACTION. El objetivo del Batch Input será la carga inicial de datos de la tabla ZTABLA_USUARIOS.
- Paso 1: la declaración de datos propios del Batch input
Declaramos una tabla interna y una estructura ambas de 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.
- Paso 2: la lectura de datos del archivo de entrada
Ejecutamos el método GUI_UPLOAD de la clase CL_GUI_FRONTEND_SERVICES para vevantar el archivo de entrada con la información para generar el Batch Input.
- Paso 3: la carga de tabla interna BDCDATA.
Para cargar la tabla interna BDCDATA utilizamos la subrutina LLENAR_TABLA_BDCDATA. Antes debemos inicializar la tabla interna del Batch Input y la de los mensajes.
Como vamos a igresar más de un registro, tendremos que manejar índices para saber en que fila de la pantalla estamos cargando los datos. Esto lo solucionamos fácilmente, concatenando el nombre del campo el número de fila que le corresponde en la pantalla entre parentesis.
- Paso 4: la ejecución de la sentencia Call Transaction
Ahora vamos a ejecuta la sentencia CALL TRANSACTION. La sintaxis de la sentencia. Veamos en detalle cada una de las opciones.
- USING: aqui especificamos la tabla interna BDCDATA que se utilizará.
- MODE: determina el modo de procesamiento que utilizará el Batch Input.
- UPDATE: determina el modo de actualización de los cambios que producirá el Batch Input.
- 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 el módulo de funciones MESSGE_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 igresar a la transacción SM30 con el nombre de la tabla base de tados ZTABLA_USUARIOS y hacemos clic en el botón Actualizar. Luego hacemos clic en el botón Entrada Nuevas. El sistema nos informa que "No existen entradas" en la tabla bese de datos ZTABLA_USUARIOS. Se cargan todos los campos del registro y hacemos clic en el botón grabar. Salimos de la dynpro en donde completamos el registro de la tabla base de datos ZTABLA_USUARIOS. Y salimos de la pantalla inicial de la transacción y reperiremos esta secuencia de pasos por cuantos registros de usuarios ingresamos en la tabla base de datos ZTABLA_USUARIOS. Finalmente si chequeamos el contenido de la tabla base de datos ZTABA_USUARIOS a traes de la transacción SE16 vamos a verificar que efectivamente existen tres registros que son los que acabamos de insertar en la tabla.
 
 
 
Sobre el autor
Publicación académica de Javier Miguel Angel Barcelo, en su ámbito de estudios para la Carrera Consultor ABAP.
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