🚀PROMO #PLANCARRERA2024 - 🔥Bonificaciones, Precios Congelados y Cuotas

 X 

✒️ABAP El Batch Input utilizando Call transaction

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.

El objetivo serà la carga de datos de la tabla ZTABLA_USUARIOS.

Se crea una estructura con registros que cumplan con la estructura de la taba ZTABLA_USUARIOS, sin tomar en cuenta el nombre del campo mandante.

- Paso uno: Declaraciòn de datos propios del Batch Input.

Declarar la tabla interna y una estructura, ambas de tipo BDCDATA, otra tabla interna del tipo

BDCMSGCOLL con su estructura 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.

*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_mensajes OCCURS 0.

INCLUDE STRUCTURE bdcmsgcoll.

DATA: END OF ti_mensajes.

* Estructura de mensajes.

DATA: st_mensajes TYPE bdcmsgcoll.

* Tabla de usuarios

DATA: ti_archivo TYPE STANDARD TABLE OF ztabla_usuarios,

st_archivo LIK 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.

"La estructura BDCMSGCOLL.- Es utilizada para definir la tabla interna que almacena los mensajes del batch input"

- Segundo paso: Lectura de datos de archivo de entrada.

Ejecutamos el mètodo GUI_UPLOAD, para levantar el archivo de entrada con la informaciòn para generar el Batch Input.

CALL METHOD cl_gui_forntend_services= gui_upaload

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

unknow_error = 7

bad_datta_format = 8

header_not_allowed = 9

separator_not_allowed = 10

header_too_long = 11

unknow_dp_error = 12

OTHERS = 19.

- Paso tercero_ Carga de la tabla BDCDATA.

A travès de la subrutina BDC:FIELD, se cara la tabla BDCDATA. Antes debemos inicializar la tabla del Batch Input y la de los mensajes.

Como se va a ingresar 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 al nombre del campo el nùmero de fila que le corresponde en la pantalla entre parèntesis.

* cargo datos del usuario.

PERFORM bdc_field USING 'X' 'SAPLZTABLA_USUARIOS'.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-DNI (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-dni.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-NOMBRE_APE (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-nombre_ape.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-ESTADO_USU (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-estado_usu.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-direccion (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-direccion.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-CODIGO_POSTAL (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-codigo_postal.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-FECHA_NAC (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-fecha_nac.

CLEAR v_campo.

CONCATENATE 'ZTABLA_USUARIOS-ESTADO_CIVIL (' v_indice ')' INTO v:campo.

PERFORM bdc_field USING ' ' v:campo st_archivo-estado_civil.

Paso cuarto: Ejecuciòn de la sentencia CALL TRANSACTION.

CALL TRANSACTION v_cod_trans USING ti_bdc_data

MODE v_modo

UPDATE v_update

MESSAGE INTO ti_mensajes.

IF NOT sy-subrc EQ 0.

v_error = 'X'.

ENDIF.

Detalles.

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:

A: Procesamiento con la visualizaciòn de todas las pantallas. Es el valor por default.

E: Procesamiento donde se muestran as pantalla solo si ocurre un error. Si se alcanza un breakPoint, se termina el procesamiento con SY-SUBRC = 1001. El campo SY-MSGTY contendrà "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. Se se alcanza un breakpoint, se pasa ek control al debugger.

"Es conveniente utilizar una variable para asignar el modo de procesamietno a un Batch input"

De esta forma podemos modificar su valor dinàmicamente, durante la ejecuciòn del programa.

UPDATE.- Determina el modo de actualizaciòn de los cambios que producirà el BI, los modos son:

A: Actualizaciòn asincrònica. La actualizaciòn se produce de igua forma a a que sucede si utilizamos la secuencia COMMIT WORK.

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 ( se utiliza la funciòn MESSAGE_PREPARE).

v_msg_id = st_messages-msgid.

v_msg_no = st_message-msgnr.

v_msg_v1 = st_message_msgv1.

v_msg_v2 = st_message_msgv2.

v_msg_v3 = st_messages-msgv3.

v_msg_v4 = st_message_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 NE 0.

MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.

ENDIF.

Ejecuciòn del Batch Input, vamos a ejecutarlo con modo de procesamiento "A"

- 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".


 

 

 


Sobre el autor

Publicación académica de Miguel Angel Acosta Acosta, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Expert


Miguel Angel Acosta Acosta

Profesión: Ingeniero de Sistemas - Ecuador - Legajo: TF64C

✒️Autor de: 238 Publicaciones Académicas

🎓Egresado de los módulos:

Disponibilidad Laboral: FullTime

Presentación:

Profesional de ingeniería de sistemas en computación e informática, con experiencia en la implantación y soporte de proyectos informáticos para empresas del sector industrial y financiero.

Certificación Académica de Miguel Acosta

✒️+Comunidad Académica CVOSOFT

Continúe aprendiendo sobre el tema "El Batch Input utilizando Call transaction" de la mano de nuestros alumnos.

SAP Master

PASOS PARA BATCH INPUT UTILIZANDO CALL TRANSACTION. 1.- Declaración de datos propias del Batch input. 2.- Lectura de datos de archivos de entrada, ejecutando el metodo CA_GUI_FRONTED_SERVICES=>GUI_UPLOAD. 3.-Carga de la tabla BDCDATA, utilizamos la subrutina BDC_FIELD. 4.- ejecusión de la sentencia CALL TRANSACTION

Acceder a esta publicación

Creado y Compartido por: Maria Ysabel Colina De Magdaleno

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

1| MI PRIMER BATCH INPUT UTILIZANDO CALL TRANSACTION SE CREARA EL BATCH INPUT UTILIZANDO LA TECNICA DE CALL TRANSACTION EL OBJETIVO DEL BATCH INPUT SERA LA CARGA INICIAL DE DATOS DE LA TABLA ZTABLA_USUARIOS PASO 1 DECLARACION DE DATOS PROPIOS DEL BATCH INPUT DECLARAREMOS UNA TABLA INTERNA Y UNA ESTRUCTURA DEL TIPO BDCDATA OTRA TABLA INTERNA DEL TIPO BDCMSGCOLL CON SU ESTRUCTURA. PASO 2 LECTURA DE DATOS DE ARCHIVO DE ENTRADA EJECUTAMOS EL METODO GUI_UPLOAD PARA LEVANTAR EL ARCHIVO DE ENTRADA CON LA INFORMACION PARA GENERAR EL BATCH INPUT. PASO 3 CARGA DE LA TABLA BDCDATA SE UTILIZARA LA SUBRUTINA BDC_FIELD. PASO 4 EJECUCION DE LA SENTENCIA CALL TRANSACCTION AHORA VAMOS A EJECUTAR LA SENTENCIA CALL TRANSACTION. VEAMOS EN DETALLE CADA UNA DE...

Acceder a esta publicación

Creado y Compartido por: Luis Eugenio Leyva Orozco

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Expert


El Batch Input utilizando la sentencia CALL TRANSACTION en ABAP es una técnica que te permite automatizar la entrada masiva de datos en SAP. Esta técnica utiliza la función CALL TRANSACTION para emular la interacción del usuario con una transacción SAP y realizar entradas o actualizaciones en lote de manera automatizada. A diferencia de la grabación de Batch Input, que crea programas automáticamente, en este caso debes construir el programa de Batch Input manualmente utilizando la sentencia CALL TRANSACTION. Es importante tener en cuenta que el uso de CALL TRANSACTION para Batch Input requiere un buen conocimiento de las transacciones SAP y cómo interactúan con los datos. También...

Acceder a esta publicación

Creado y Compartido por: Darling Geraldino

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

mi primer batch input utilizando CALL TRANSACTION vamos a crear nuestro primer batch input utilizando la tecnica de CAL TRANSACTION. El objetivo de batch input sera la carga inicial de datos de la tabla ZTABLA_USUARIOS. primer paso declaracion de datos propios de batch input declaramos una tabla interna y una estructura, ambas del tipo BDCDATA, otra tabla interna del tipo BDCMSGCOLL. con su estructura, que serviran para almacenar los mensajes que se produzcan cuando ejecutamos el call trasaction, la tabla interna de usuarios. que contendra los datos que levantamos del archivo de entrada y una tabla para mastrar por pantalla los errores entre otras declaraciones. segundo paso lectura de datos de archivo de entrada. ejecutamos el metodo GUI_UPLOAD...

Acceder a esta publicación

Creado y Compartido por: Oscar Sebastian Caicedo Carlier / Disponibilidad Laboral: PartTime + Carta Presentación

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

Creacion del primer batch input utilizando CALL TRANSACTION. ESTRUCTURA BCDMSGCOLL es una estructura estandar del sistema, es utilizada para definir la tabla interna que almacenara los mensajes del batch input.

Acceder a esta publicación

Creado y Compartido por: Rainer Diaz

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Expert

1 - BATCH INPUT UTILIZANDO CALL TRANSACTION. CALL TRANSACTION: se realiza de forma Online, por lo que ejecuta las actualizaciones en el momento en que se ejecuta el programa del Batch Input. Se utiliza la sentencia estándar CALL TRANSACTION. Los pasos para la realización de un Batch Input mediante la técnica de CALL TRANSACCTION son los siguientes: 1ero: Declaración de datos propios del Batch Input. Declarar Tabla Interna y Esructura del tipo BDCDATA (Guarda los datos a cargar en la tabla). Declarar Tabla Interna y Esructura del tipo BDCMSGCOLL (Guardar los mensajes que se producen durante la ejecución). 2do: Lectura de datos de archivo de entrada.generar el Batch Input. Ejecutar el metodo GUI_UPLOAD para...

Acceder a esta publicación

Creado y Compartido por: Francisco Javier Gomez Jimenez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

BATCH INPUT UTILIZANDO CALL TRANSACTION declaracion de datos propios del batch input declaramos una tabla interna y una estructura, ambas del tipo BDCDATA, otra tabla interna del tipo BDCMDHCOLL con su estructura,que serviran para almacenar los mensajes que se produzcan cuando ejecutemos CALL TRANSACTION, la tabla interna usuarios, que contendra los datos que levantemos del archivo de entrada y una tabla para mostrar por pantalla los errores entre otras declaraciones. lectura de datos de archivo de entrada ejecutamos el metodo CL GUI FRONTEND SERVICES=> GUI UPLOAD para levantar el archivo de entrada con la informacion para generar el batch input carga de la tabla BDCDATA para cargar la tabla BDCDATA utilizamos la subrutina...

Acceder a esta publicación

Creado y Compartido por: Luis Car

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Batch Input utilizando call transaction. call transaction: Sentencia estándar ABAP que permite la llamada a una transacción SAP Carga inicial de datos: Proceso que consiste en el ingreso de los datos necesarios para el funcionamiento de una aplicación en un ambiente del sistema. BDCMSGCOLL: Estructura estándar SAP que se utiliza para almacenar los mensajes de la ejecución de un CALL TRANSACTION. Paso para carga inicial. 1.- Declaración de datos propios del batch input. 2.- Lectura de datos de archivo de entrada. 3.- Carga de la tabla BDCDATA. 4.- Ejecución de la sentencia Call Transaction. 5.- Ejecutarlo con modo de procesamiento A, que nos permite ver los pasos de las actualizaciones....

Acceder a esta publicación

Creado y Compartido por: Rafael Razo

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master


Batch Input Utilizando Call Transaction Abap batch input utilizando call transaction existen dos técnicas para realizar un Batch Input, una se realiza de forma Online y la otra en forma Batch. Ellas son: CALL TRANSACTION: se realiza de forma Online, por lo que ejecuta las actualizaciones en el momento en que se ejecuta el programa del Batch Input. Se utiliza la sentencia estándar CALL TRANSACTION. JUEGO DE DATOS: se realiza de forma Batch (o de fondo) y queda almacenado en SAP para su posterior ejecución mediante la transacción SM35. Consiste en la ejecución de una serie de funciones estándar para la apertura, ejecución y cierre del juego de datos. Los pasos para la realización de...

Acceder a esta publicación

Creado y Compartido por: Cesar Armando Gutierrez Gomez / Disponibilidad Laboral: FullTime

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

BATCH INPUT CON CALL TRANSACTION Para realizar un BI con call transaction debemos seguir los siguientes pasos: Declaración de tabla y estructura del tipo bdcdata; declaración de tabla y estructura del tipo bdcmsgcoll para almacenar los mensajes del call transaction; declaración de tabla y estructura de datos; declaración de tabla y estructura de errores Lectura de datos del archivo de entrada con el método gui_upload Carga de la tabla bdcdata con la subrutina bdc_field utilizando índices para cargar más de un registro Ejecutar call transaction como: CALL TRANSACTION v_cod_trx USING ti_bdc_data MODE v_mode UPDATE v_update MESSAGES INTO ti_messages. En la sentencia call transaction...

Acceder a esta publicación

Creado y Compartido por: Jonatan Richioni

 


 

👌Genial!, estos fueron los últimos artículos sobre más de 79.000 publicaciones académicas abiertas, libres y gratuitas compartidas con la comunidad, para acceder a ellas le dejamos el enlace a CVOPEN ACADEMY.

Buscador de Publicaciones:

 


 

No sea Juan... Solo podrá llegar alto si realiza su formación con los mejores!