🚀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 MEDIANTE CALL TRANSACTION

Primero: hay que crear una archivo de texto con la estructura de la tabla que queremos cargar sin el campo MANDT

Segundo: ya que hacemos una carga de datos desde cero, hacemos una limpieza de la tabla

Tercero: declaraciones de tablas y estructuras

1 tabla del tiopo BDCDATA

1 estructura del tipo BDCDATA

1 tabla del tipo BDCMSGCOLL (almacenan mensajes que se produzcan cuando ejecutemos el CALL transacción

1 estructura del tipo BDCMSGCOLL

La tabla interna que rellenaremos con los datos y su estructura

1 tabla para mostrar los errores

NOTA: La estructura BDCMSGCOLL es una estructura estándar del sistema, es utilizada para definir la tabla interna que almacenará los mensajes del batch input.

EJEMPLO:

* TABLA DEL BATCH INPUT CON LA ESCTRUCTURA 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 OCCURIS 0.

INCLUDE STRUCTURE bdcmsgcoll.

DATA: END OF ti_messages.

*ESTRUCTURA DE MENSAJES

DATA: st_messages TYPE bdcmsgcoll.

* Taba que rellenamos

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.

Cuarto: lectura de los datos de archivo de entrada, mediante el método GUI_UPLOAD

Quinto: Cargar la tabla BDCDATA.

Ya que se van a rellenar muchos datos, deberemos utilizar índices, pera ello tendremos que contatenar al nombre del campo el numero de fila que le corresponde en la pantalla entre paréntesis, como muestra el ejemplo:

PERFORM bdc_field USING ‘X’ ‘SAPLZTABLA_USUARIOS’ ‘0002’.

CLEAR v_campo.

CONCATENATE ‘ZTABLA_USUARIOS-DIN(‘ v-indice ’)’ INTO v_vampo.

PERFORM bdc_field USING ‘ ‘ vcampo st_archivo-dni.

Sexto: ejecución de la sentencia CALL TRANSACTION

Sintaxis:

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.

MODIFICADORES:

USING: aquí especificamos la tabla BDCDATA que se usará.

MODE: determina el modo de procesamiento que usará el BATCH INPUT

A: Procesamiento con la visualización de todas las pantallas, es el valor por defecto.

E: Procesamoiento donde solo se muestran las pantalla soso si ocurre un error. Si se alcanza un breakpoint, se termina el procesmiento con SY-SUBRC iaugal a 1001. El campo SY_MSGTY contendraá “S”. SY_MSGID contendrá “00”, SY_MSGNO contendrá “344”, SY_MSGV1 contendra “SAPMSSY3” y SY_MSGV2 contendrá el “0131”

N: Procesamiento donde no se muestran las pantalla.

P: Procesamiento donde se muestran las pantallas. Si se alcanza un breakpont, se pasa el control al debugger.

NOTA: Es conveniente utilizar una variable para asignar el modo de procesamiento, de esta forma podremos modificar su valor dinámicamente, durante la ejecución del mismo.

UPDATE: determina el modo de actualización de los cambios

A: Actulizacion Asincronoa, la actualización se produce de igual forma a la que sucede si utilizamos la sentencia COMMIT WORK. Este es el valor por defecto.

S: Actualizacion Sincrona. La actualización síncrona se produce de igual forma a la que sucede si utilizamos la senentcia COMMIT WORK AND WAIT.

L: Actualizacion Local

MESSAGES INTO: todos los mensajes generados durante el procesamiento del batch son almacenados en una tabla interna. Para construir los mensajes vamos a utilizar la función MESSAGE_PREPARE tal y como se muestra aquí:

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_sburc <> 0.

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

ENDIF.

NOTA: La sentencia CALL TRANSACION 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 clausula AND SKIP FIRST SCREEN.


 

 

 

Agradecimiento:

Ha agradecido este aporte: Cristina Fraile Del Rio


Sobre el autor

Publicación académica de Josep Antoni Lopez Moyano, en su ámbito de estudios para la Carrera Consultor ABAP.

✒️+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 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 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 Senior

CALL TRANSACTION: Sentencia estandar que permite la llamada a una transaccion SAP. BDCDATA: Estructura estandar que se utiliza para la carga de datos en un Batch Input. BDCMSGCOLL: Estructura estandar que se utiliza para almacenar los mensajes resultantes de la ejecucion de un CALL TRANSACTION. CL_GUI_FRONTEND_SERVICES=>GUI_UPLOAD: Metodo estandar que se utiliza para levantar archivos locales. MESSAGE_PREPARE: Funcion estandar que se utiliza para el armado de mensajes generalmente en un Batch Input.

Acceder a esta publicación

Creado y Compartido por: David Camacho Espinoza

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

SAP Senior

Lección: 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 obejtivo 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 ejemplo. Ahora, seguiremos los pasos que establecimos en la primer lección de la unidad. Declaración de datos propios del Batch Input...

Acceder a esta publicación

Creado y Compartido por: Pedro Alejandro Arroyo Gutierrez

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

SAP Master

***************** Batch Input utilizando Call transaction [ 4º de 8 ] Crear Batch Input utilizando la técnica de CALL TRANSACTION (Sentencia estándar ABAP que permite la llamada a una transacción SAP) El objetivo del Batch Input será la carga inicial de datos de dicha tabla. Se crea un archivo de texto con registros que cumplan con la estructura de la tabla, SIN TENER EN CUENTA EL CAMPO MANDANTE. PASO1: Declaración de datos propios del batch input Se declara una tabla interna y una estructura, ambas tipo BDCDATA. Otra tabla interna del tipo BDCMSGCOLL con su estructura, que servirán para almacenar los mensajes que se produzcan cuando se ejecuta el CALL TRANSACTION, la tabla interna de usuarios,...

Acceder a esta publicación

Creado y Compartido por: Jose Angel Valles Bustos

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

SAP SemiSenior

Batch input utilizando call transaction. El objetivo del batch input será la carga inicial de datos de la tabla ZTABLA_USUARIOS. Pasos. 1. Declaración de datos propios del bacth 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 utilzada para definir la tabla interna que almacenará los mensajes...

Acceder a esta publicación

Creado y Compartido por: Fabio Gallo

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

SAP Master

Mi primer Batch Input utilizando CALL TRANSACTION. Para crear el programa de carga inicial de usuarios con la técnica CALL TRANSACTION, procesamos los siguientes pasos que vimos en la lección 1: Declaración de datos propios del Batch Input. Lectura de datos de archivo de entrada. Carga de la tabla BDCDATA. Ejecución de la sentencia CALL TRANSACTION. Observaciones de la practica: Hay que tener mucho cuidado cuando generamos el archivo de texto que vamos a levantar de nuestra PC, hay que verificar que las separaciones entre campos sea la correcta, ya que en el campo de "Estado de Usuario" no me ponía nada, y ese dato lo ponía junto con la dirección en el campo de "Dirección",...

Acceder a esta publicación

Creado y Compartido por: Calixto Gutiérrez

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

SAP Senior

MI PRIMER BATCH INPUT UTILIZANDO CALL TRANSACTION: 1. Creación del archivo de texto: para esto ver el Código Fuente del ejemplo en la lección. 2. Se siguen los pasos de la lección 1 de esta unidad. Analizar cuidadosamente estos pasos. La estructura BDCMSGCOLL sirve para definir la tabla interna que almacenará los mensajes del batch input. La sintaxis de la sentencia CALL TRANSACTION es: CALL TRANSACTION v_cod_trans USING ti_bdc_data MODE v_modo MESSAGES INTO ti_messages. ...

Acceder a esta publicación

Creado y Compartido por: Pedro Ernesto Maldonado

 


 

👌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!