✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
4.- Módulo de función RFC
El objetivo principal de las RFC es acceder a otros ambientes para obtener datos.
La comunicación puede darse entre sistemas SAP o entre un sistema SAP y otro sistema que no sea SAP.
Para llamar a una función RFC se debe agregar la cláusula DESTINATION al momento de declarar la función, ejemplo:
Ejemplo leer un registro de un cliente del sistema DCR, a través de un programa ABAP existente en el ambiente DTR, crearíamos una RFC en DCR que devuelva los registros de los clientes. Luego llamaríamos a esta función en DTR, utilizando un destino que previamente hemos creado a través de la transacción SM59:
3.1.- Crear una RFC
Una función RFC se crea de la misma manera que se crea una función. Se accede a la transacción SE37 y se completan los mismos parámetros que completamos para crear una función a excepción de que se debe seleccionar en la solapa de Atributos la opción Módulo de acceso remoto (Remote Enabled Module).
Las funciones creadas como RFC, pueden ser utilizadas como módulos de función Normales. De dos maneras diferentes:
3.2.- Tipos de RFC
Existen tres tipos de RFC:
Sincrónicas: ambos sistemas deben estar disponibles al momento de la llamada de la función, Estas RFC están basadas en una comunicación sincrónica.
Transaccionales: los sistemas no necesitan estar disponibles al momento de la llamada a la función. Un único ID de transacción es generado y los programas llamados son almacenados en el sistema junto con los datos. Para crear una RFC transaccional debo utilizar el sufijo IN BACKGROUND TASK:
En las RFC transaccionales, el sistema deja un log con el pedido de la llamada remota en las tablas estándar de SAP ARFCSSTATE y ARFCSDATA con todos los valores de los parámetros pasados en la ejecución. Para visualizar este log, utilizaremos la transacción SM58.
Para visualizar este log, se utiliza la transacción SM58.
Cuando el programa que ejecuta la RFC ejecuta la sentencia COMMIT WORK, entonces es cuando la llamada remota es enviada al sistema remoto para su ejecución.
Asincrónicas: el programa llamador, llama a la función RFC e inmediatamente después termina su procesamiento. Luego la función RFC se ejecuta independientemente del programa llamador, Para crear una RFC asincrónica debo utilizar el sufijo STARTING NEW TASK :
 
 
 
Sobre el autor
Publicación académica de Pablo Galeana, en su ámbito de estudios para la Carrera Consultor ABAP.
Pablo Galeana
Profesión: Java-oracle-linux - Mexico - Legajo: XR73U
✒️Autor de: 57 Publicaciones Académicas
🎓Egresado del módulo:
Certificación Académica de Pablo Galeana