✒️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 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 q cumplan con la estructura de la tabla ZTABLA_USUARIOS, sin tener en cuenta al campo mandante.
Como lo q vamos a hacer será la carga inicial de la tabla de usuarios, borraremos su contenido previamente a la ejecución de este ejemplo. Ahora, seguiremos los pasos q establecimos en la primer lección de la unidad.
- Paso 1ero.: 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, q servirán para almacenar los mensajes que se produzcan cuando ejecutamos el CALL TRANSACTION, la tabla interna de usuarios, q contendrá los datos q levantemos del archivo de entrada y una tabla para mostrar por pantalla los errores entre otras declaraciones.
Ej: Declaramos los tipos de datos necesarios para realizar el BI
* Tabla del BI con la estructura de BDCDATA
DATA: BEGIN OF ti_bdc_data OCCURS 0.
INCLUDE STRUCTURE bdcdata.
DATA: END OF ti_bdc_data.
* Estructura del BI
DATA: st_bdc_data TYPE bdcdata.
* Tabla de mensajes
DATA: BEGIN OF ti_messages OCCURS 0.
INCLUDE STRUCTURE bdcmsgcoll.
DATA: END OF ti_messages.
* Estructura de mensajes
DATA: st_messages TYPE bdcmsgcoll.
* Tabla de usuarios
DATA: ti_archivo TYPE STANDARD TABLE OF ztabla_usuarios,
st_archivo LIKE LINE OF ti_archivo.
* Tabla de errores
DATA: BEGIN OF ti_errores OCCURS 0,
dni TYPE z_dni,
descripcion(100) TYPE c,
END OF ti_errores.
NOTAS: Estructura BDCMSGCOLL
Esta estructura estándar del sistema es utilizada para definir la tabla interna q almacenará los mensajes del batch input.
- Paso 2do.: Lectura de datos de archivos de entrada
Ejecutamos el método GUI_UPLOAD para levantar el archivo de entrada con la información para generar el Batch Input.
- Paso 3ero.: Carga de la tabla BDCDATA
Para cargar la tabla BDCDATA utilizamos la subrutina BDC_FIELD, q 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 q manejar indices para saber en q fila de la pantalla estamos cargando los datos. Esto lo solucionamos fácilmente, concatenando al nombre del campo el número de fila q le corresponde en la pantalla entre paréntesis.
- Paso 4to.: Ejecución de la sentencia CALL TRANSACTION
Ahora vamos a ejecutar la sentencia CALL TRANSACTION. La sintaxis de la sentencia es la siguiente:
Ej: Ejecución de la sentencia CALL TRANSACTION
* Call transaction
CALL TRANSACTION v_cod_trans USING ti_bdc_data
MODE v_modo
UPDATE v_update
MESSAGES INTO ti_messages.
IF NOT sy-subrc EQ 0.
v_error = 'X'.
ENDIF.
Veamos en detalle cada una de las opciones.
- USING: aquí especificamos la tabla BDCDATA q se utilizará.
- MODE: determina el modo de procesamiento q utilizará el Batch Input. Los modos posibles de procesamiento son:
A Procesamiento con la visualización de todas las pantallas. Es el valor por default.
B Procesamiento donde se muestran las pantallas solo si ocurre un error.
Si se alcanza un breakpoint, se termina el procesamiento con
SY-SUBRC = '1001' El campo SY-MSGTY = 'S', SY-MSGID = '00', SY-MSGNO = '344',
SY-MSGV1 = 'SAPMSSY3', SY-MSGV2 = '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 control al debugger.
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.
Cuando estamos desarrollando un programa q realiza un Batch Input mediante la técnica 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 q en caso de error en los datos q introducimos en la tabla BDCDATA el procesamiento se detendrá en la pantalla correspondiente al error y será allí donde tendremos q analizar como solucionarlo, una vez q detectamos y corregimos el error, podemos modificar el modo de ejecución AN.
- UPDATE: determina el modo de actualización de los cambios q producirá el Batch Input. Los modos posibles son:
A Actualización Asincrónica.
La actualización se produce de igual forma a la q sucede si utilizamos la sentencia COMMIT
WORK.
Vale por defecto.
S Actualización Sincrónica.
La actualización se produce de igual forma a la q sucede si utilizamos la sentencia COMMIT
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 q ya terminamos con todos los pasos del BI, vamos a ejecutarlo con modo de procesamiento "A", q nos permite ver el paso a paso de las actualizaciones.
Lo primero q 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 usuarios ingresemos en la tabla.
IMPORTANTE: 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 Mayra Maria Pino Rodriguez, en su ámbito de estudios para la Carrera Consultor ABAP.
Mayra Maria Pino Rodriguez
Profesión: Licenciada Cibernética Matemática - Republica Dominicana - Legajo: RA62Z
✒️Autor de: 56 Publicaciones Académicas
🎓Egresado del módulo:
Certificación Académica de Mayra Pino