✒️ABAP El Batch Input utilizando Call transaction
ABAP El Batch Input utilizando Call transaction
1. Primer batch Input utilizando el CALL TRANSACTION
El objetivo principal será la carga inicial de datos de la tabla ZTABLA_USUARIOS. Para eso se tiene que crear un archivo txt con la misma estructura que la tabla.
Siguiendo los pasos para el call Transaction seria :
1ro. Declaracion de datos propios del Batch Input:
*Tabla del BI con la estructura del 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.
*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 c ,
descripcion(100) TYPE c,
DATA: END OF ti_errores .
BDCMSGCOLL : Estructura estándar del sistema es utilizada para definir la tabla de interna que almacenará los mensajes del Batch Input.
2do. Lectura de datos de archivo de Entrada.
· Se abre el archivo de entrada para lectura
CALL METHOD cl_gui_frontend_services=>gui_upload
EXPORTING
filename = vl_file
filetype = ‘ASC’
has_field_separator = ‘ ‘
CHANGING
Data_tab = ti_archivo []
EXCEPTIONS
file_open_error = 1
file_read_error = 2
no_batch = 3
gui_refuse_filetransfer = 4
invalid_type = 5
no_authority = 6
unknown_error = 7
bad_data_format = 8
header_not_allowed = 9
separator_not_allowed = 10
header_too_long = 11
unknown_dp_error = 12
access_denied = 13
dp_out_of_memory = 14
disk_full = 15
dp_timeout = 16
not_supported_by_gui = 17
error_no_gui = 18
OTHERS = 19.
3er Paso Carga de la Tabla BDCDATA
· Cargo datos del usuario
PERFORM bdc_field USING ‘X’ ‘SAPLZTABLA_USUARIOS’ ‘0002’ .
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-DNI’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-dni.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-NOMBRE_APE’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-nombre_ape.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-ESTADO_USU’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-estado_usu.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-DIRECCION’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-direccion.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-CODIGO_POSTAL’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-codigo_postal.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-F_NACIMIENTO’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-f_nacimiento.
CLEAR v-campo.
CONCATENATE ‘ZTABLA_USUARIO-ESTADO_CIVIL’ (‘v_indice’)’ INTO v_campo.
PERFORM bdc_field USING ‘ ‘ v_campo st_usuario-estado_civil.
4To Paso Ejecución del CALL TRANSACTION
· Llamada al TRANSACTION
CALL TRANSACTION v_cod_trans USING ti_bdc_data MODE v_modo
MESSAGES INTO ti_messages.
IF NOT sy-subrc IS INITIAL.
v_error = ‘X’.
ENDIF.
· USING : especificamos la Tabla BDCDATA que se utilizará.
· MODE : determina el mode de procesamiento que utilizará el batch Input. Los posibles son
MODO |
Efecto |
A |
Procesamiento co la visualización de todas las pantallas.Es el valor por default. |
E |
Procesamiento donde se muestran las pantallas solo si ocurre el error. Si se alcanza el Breakpoint , se termina el procesamiento con SY_SUBRC=1001. El campo SY_MSGTY = “S”, SY-MSGID=”00” SY-MSGNO=”344” , SY-MSGV1=’SAPMSSY3’ y SY-MSGV2=’0131’ |
N |
Procesamiento donde no se muestran las pantallas |
P |
Procesamiento donde no se muestran las pantallas. Si se alcanza el breakpoint , se pasa el control al debugger. |
Es conveniente utilizar una variable para asignar el modo de procesamiento de Batch Input.Asi podremos modificar su valor dinámicamente durante la ejecución del programa.
Audio:
Cuando estamos desarrollando un programa que realiza el batch input mediante la técnica de CALL TRANSACTION es muy útil utilizar el modo de ejecución A ya que nos permite visualizar cada una de las pantallas ya que en caso de error en los datos que introdujimos en la tabla BDCDATA el procesamiento se detendrá en la pantalla correspondiente al error y es allí donde debemos analizar el error, una vez que sea corregido podemos cambiar al modo de ejecución N.
· UPDATE : determina el modo de actualización de los cambios que producirá el Batch Input
Update |
Efecto |
A |
Actualización Asincrónica. La act.se produce igual forma a la que sucede con el COMMIT WORK Vale por defecto |
S |
Actualización Sincrónica. La act.se produce igual forma a la que sucede con el COMMIT WORK AND WAIT
|
L |
Actualización Local |
v_msg_id = st_messages-msgid.
v_msg_no = st_messages-msgnr.
v_msg_v1 = st_messages-msgv1.
v_msg_v2 = st_messages-msgv2.
v_msg_v3 = st_messages-msgv3.
v_msg_v4 = st_messages-msgv4.
CALL FUNCTION ?MESSAGE PREPARE’
EXPORTING
msg_id = v_msg_id
msg_no = v_msg_no
msg_var1 = v_msg_v1
msg_var2 = v_msg_v2
msg_var3 = v_msg_v3
msg_var4 = v_msg_v4
IMPORTING
Msg_text = v_mensaje
EXCEPTIONS
Function_not_completed = 1
Message_not_found = 2
OTHERS = 3
IF SY_SUBRC <> 0.
MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy_msgno WITH sy-msgv1 sy-msgv2
sy_msgv3 sy-msgv4.
ENDIF.
para ejecutar en Modo de procesamiento "A" ingresamos al SM30 con el nombre de la Tabla(ZTABLA_USUARIOS) y presionamos el botón de Actualizar . Luego presionamos Entradas nuevas (New ENTRIES) se cargan los campos del registro y presionamos grabar.
Finalmente salimos de la transaccion y repetiremos esta secuencia de pasos por cuantos registros de usuario ingresemos en la tabla.
La sentencia CALL TRANSACTION también es utilizada en reportes, para acceder a una transaccion determinada, a partir delos datos presionados en pantalla, con el agregado de la cláusula AND SKIP FIRST SCREEN.
 
 
 
Sobre el autor
Publicación académica de Carlos Alberto Carreira, en su ámbito de estudios para la Carrera Consultor ABAP.
Carlos Alberto Carreira
Profesión: Consultor Técnico en Jde W.s. - Argentina - Legajo: KC15G
✒️Autor de: 92 Publicaciones Académicas
🎓Cursando Actualmente: Consultor ABAP Nivel Inicial
🎓Egresado de los módulos:
Certificación Académica de Carlos Carreira