✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
LOS MÓDULOS DE FUNCIÓN RFC
Consiste en una llamada a una función que existe en un sistema distinto al del programa que la llama.
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.
La RFC llamada no existe en el sistema origen pero si debe existir en el sistema destino.
¿CÓMO 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 ATRIBUTOS la opción MÓDULO DE ACCESO REMOTO (REMOTE ENABLED MODULE).
NOTA: los parámetros que se crean en una función RFC no se pueden pasar por referencia, deben pasarse por valor.
Esto se logra tildando el check TRANSPORTAR VALORES (PASS VALUE) para cada parámetro en las solapas IMPORT, EXPORT y CHANGING.
A su vez, las funciones creadas como RFC, pueden ser utilizadas como módulos de función normales. Esto se logra de dos maneras diferentes:
- Utilizando la declaración CALL FUNCTION DESTINATION 'NONE'.
- Utilizando la declaración de un módulo de función normal, sin el agregado de la cláusula DESTINATION.
TIPOS DE RFC
Existen 3 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. Generalmente, utilizamos el tipo de RFC sincrónico para la mayoría de nuestros desarrollos.
- 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 ARFCSTATE ARFCSDATA con todos los valores de los parámetros pasados en la ejecución.
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.
Utilizaremos el tipo de RFC transaccional para ciertos casos específicos de actualizaciones donde no se requiera que dichas actualizaciones se realicen en forma inmediata sino recién cuando el programa llamador ejecuta un COMMIT WORK,
- 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 .
No es posible debuggear una llamada a una función remota de otro sistema, sin embargo, cuando estamos probando una llamada a una RFC desde un sistema SAP a otro sistema SAP, podemos utilizar el debugger para monitorear la ejecución de la función RFC en el sistema remoto. Con las llamadas remotas el debugger ABAP se ejecuta en el sistema local, los valores de los datos y otra información de ejecución de la función remota son pasadas al sistema remoto.
 
 
 
Sobre el autor
Publicación académica de Ducelvis Lolimar Arcia Cova, en su ámbito de estudios para la Carrera Consultor ABAP.
Ducelvis Lolimar Arcia Cova
Profesión: Tsu Relaciones Industriales (rrii) - Argentina - Legajo: WX74T
✒️Autor de: 125 Publicaciones Académicas
🎓Egresado de los módulos:
- Carrera Consultor en SAP FI Nivel Inicial
- Carrera Consultor ABAP Nivel Avanzado
- Carrera Consultor ABAP Nivel Inicial
Disponibilidad Laboral: FullTime
Presentación:
Mi principal objetivo al comenzar esta gran experiencia educativa en programación abap es adquirir los conocimientos y competencias necesarias para incorporarme en el ámbito laboral en esta área.
Certificación Académica de Ducelvis Arcia