Paquete DBMS_CLOUD_FUNCTION
El paquete DBMS_CLOUD_FUNCTION le permite invocar funciones remotas de OCI y AWS Lambda en su base de datos de IA autónoma como funciones SQL.
Note:
El soporte paraDBMS_CLOUD_FUNCTION está disponible en Oracle Database 19c a partir de la versión 19.29 y en Oracle AI Database 26ai a partir de la versión 23.26.
Resumen de Subprogramas DBMS_CLOUD_FUNCTION
DBMS_CLOUD_FUNCTION.
Tabla: Subprogramas DBMS_CLOUD_FUNCTION
| Subprograma | Descripción |
|---|---|
| CREATE_CATALOG Procedimiento | Este procedimiento crea un catálogo. |
| CREATE_FUNCTION Procedimiento | Este procedimiento crea funciones en un catálogo. |
| DROP_CATALOG Procedimiento | Este procedimiento borra un catálogo y las funciones creadas mediante el catálogo. |
| DROP_FUNCTION Procedimiento | Este procedimiento borra las funciones de un catálogo. |
| LIST_FUNCTIONS Procedimiento | Este procedimiento enumera todas las funciones de un catálogo. |
| SYNC_FUNCTIONS Procedimiento | Este procedimiento permite agregar nuevas funciones al catálogo y eliminar las funciones que se han suprimido del catálogo. |
CREATE_CATALOG Procedimiento
El procedimiento DBMS_CLOUD_FUNCTION.CREATE_CATALOG crea un catálogo en la base de datos. Un catálogo es un juego de funciones que crea la infraestructura necesaria para ejecutar subrutinas.
Sintaxis
DBMS_CLOUD_FUNCTION.CREATE_CATALOG (
credential_name IN VARCHAR2,
catalog_name IN VARCHAR2,
service_provider IN VARCHAR2,
cloud_params IN CLOB
);
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre de la credencial para la autenticación. Este parámetro es obligatorio. |
|
|
Especifica el tipo de proveedor de servicios. Este parámetro puede tener Este parámetro es obligatorio. |
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
|
|
Proporciona un parámetro para la función. Por ejemplo, OCID de compartimento y regiones. Este parámetro es obligatorio. |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se emite en la siguiente condición:
|
|
|
Este error se emite en la siguiente condición:
|
|
|
Este error se emite en la siguiente condición:
|
|
|
Este error se produce cuando el proveedor de servicios no existe. |
Ejemplos
BEGIN
DBMS_CLOUD_FUNCTION.CREATE_CATALOG (
credential_name => 'DEFAULT_CREDENTIAL',
catalog_name => 'OCI_DEMO_CATALOG',
service_provider => 'OCI',
cloud_params => ("region_id":"us-phoenix-1", "compartment_id":"compartment_id"
);
END;
/
Notas de uso
-
Para crear un catálogo, debe estar conectado como usuario
ADMINo tener privilegios en lo siguiente:-
DBMS_CLOUD_OCI_FNC_FUNCTIONS_INVOKE -
DBMS_CLOUD_OCI_FNC_FUNCTIONS_INVOKE_INVOKE_FUNCTION_RESPONSE_T -
DBMS_CLOUD -
Leer privilegio en
USER_CLOUD_FUNCTION -
Leer privilegio en
USER_CLOUD_FUNCTION_CATALOG
-
CREATE_FUNCTION Procedimiento
Este procedimiento crea funciones en un catálogo.
Sintaxis
El procedimiento DBMS_CLOUD_FUNCTION.CREATE_FUNCTION solo se admite para funciones en la nube.
DBMS_CLOUD_FUNCTION.CREATE_FUNCTION (
credential_name IN VARCHAR2,
catalog_name IN VARCHAR2,
function_name IN VARCHAR2,
function_id IN VARCHAR2,
input_args IN CLOB DEFAULT NULL,
return_type IN VARCHAR2 DEFAULT 'CLOB',
response_handler IN VARCHAR2 DEFAULT NULL
);
Firma del manejador de respuestas
<USER DEFINED TYPE> response_handler_name(function_response in CLOB)RETURNS CLOB;
El tipo de retorno es el tipo definido por el usuario o el tipo PL/SQL. function_response es de JSON con campos.
'{
"STATUS":"<RESPONCE STATUS>",
"RESPONSE_BODY":"<FUNCTION RESPONSE>"
}'
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre de la credencial para la autenticación. Este parámetro es obligatorio. |
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
|
|
Especifica el nombre de la función PL/SQL. Este parámetro es obligatorio. |
|
|
El valor del parámetro Este parámetro es obligatorio. |
|
|
Especifica el par JSON de valor de clave que acepta argumentos de entrada y sus tipos. |
|
|
Define el tipo que devuelve la función. El tipo de retorno es del tipo de dato |
|
|
Especifica la devolución de llamada definida por el usuario para manejar la respuesta. |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se emite cuando la credencial a la que se hace referencia en |
|
|
Este error se produce cuando el catálogo especificado no existe. |
|
|
Este error se emite cuando la función especificada ya existe. |
|
|
Este error se produce cuando el ID de función o la función Nombres de recursos de Amazon (ARN) no existen. |
|
|
Este error se emite cuando los argumentos de entrada no son válidos. |
|
|
Este error se genera cuando falta el tipo de devolución o no es válido. |
|
|
Este error se emite cuando falta el manejador de respuestas o no es válido. |
Ejemplo
VAR function_args CLOB;
EXEC :function_args := TO_CLOB('{"command": "VARCHAR2", "value": "VARCHAR2"}');
BEGIN
DBMS_CLOUD_FUNCTION.CREATE_FUNCTION (
credential_name => 'DEFAULT_CREDENTIAL',
catalog_name => 'OCI_DEMO_CATALOG',
function_name => 'demo_function',
function_id => 'ocid1.fnfunc.oc1.phx.aaaaaaaazkrbjv6ntowwxlbbp5ct4otsj4o2hdw4ayosyosv4sthmya2lyza',
input_args => :function_args);
);
END;
/
DROP_CATALOG Procedimiento
El procedimiento DBMS_CLOUD_FUNCTION.DROP_CATALOG borra el catálogo y las funciones creadas mediante el catálogo.
Sintaxis
DBMS_CLOUD_FUNCTION.DROP_CATALOG (
catalog_name IN VARCHAR2
);
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se produce cuando el catálogo especificado no existe. |
Por ejemplo:
BEGIN
DBMS_CLOUD_FUNCTION.DROP_CATALOG (
catalog_name => 'OCI_DEMO_CATALOG'
);
END;
/
DROP_FUNCTION Procedimiento
El procedimiento DBMS_CLOUD_FUNCTION.DROP_FUNCTION borra la función.
Sintaxis
El procedimiento DBMS_CLOUD_FUNCTION.DROP_FUNCTION solo se admite para funciones en la nube.
DBMS_CLOUD_FUNCTION.DROP_FUNCTION (
catalog_name IN VARCHAR2,
function_name IN VARCHAR2
);
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
|
|
Especifica el nombre de la función que se va a borrar. Este parámetro es obligatorio. |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se emite cuando la función especificada no existe. |
Ejemplos
BEGIN
DBMS_CLOUD_FUNCTION.DROP_FUNCTION (
catalog_name => 'OCI_DEMO_CATALOG',
function_name => 'demo_function');
END;
/
LIST_FUNCTIONS Procedimiento
Este procedimiento enumera todas las funciones de un catálogo.
Sintaxis
DBMS_CLOUD_FUNCTION.LIST_FUNCTIONS (
credential_name IN VARCHAR2,
catalog_name IN VARCHAR2,
function_list OUT VARCHAR2
);
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre de la credencial para la autenticación. Este parámetro es obligatorio. |
|
|
Devuelve la lista de funciones en formato JSON. Este parámetro es obligatorio. |
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se produce cuando se transfieren valores de parámetros incorrectos. |
|
|
Este error se emite cuando la credencial a la que se hace referencia en |
|
|
Este error se produce cuando el catálogo especificado no existe. |
Por ejemplo:
VAR function_list CLOB;
BEGIN
DBMS_CLOUD_FUNCTION.LIST_FUNCTIONS (
credential_name => 'DEFAULT_CREDENTIAL',
catalog_name => 'OCI_DEMO_CATALOG',
function_list => :function_list);
);
END;
/
SELECT JSON_QUERY(:function_list, '$' RETURNING VARCHAR2(32676) pretty) AS search_results FROM dual;
SYNC_FUNCTIONS Procedimiento
Este procedimiento permite agregar nuevas funciones al catálogo y eliminar las funciones que se han suprimido del catálogo.
Sintaxis
DBMS_CLOUD_FUNCTION.SYNC_FUNCTIONS (
catalog_name IN VARCHAR2,
refresh_rate IN VARCHAR2 DEFAULT 'DAILY'
);
Parámetros
| parámetro | Descripción |
|---|---|
|
|
Especifica el nombre del catálogo. Este parámetro es obligatorio. |
|
|
Especifica el ratio de refrescamiento de la función. refresh_rate puede aceptar los siguientes valores:
El valor por defecto del parámetro es |
Errores
| Código de error | Descripción |
|---|---|
|
|
Este error se produce cuando el catálogo especificado no existe. |
|
|
Este error se emite cuando se transfiere un valor no válido para el parámetro |
Por ejemplo:
BEGIN
DBMS_CLOUD_FUNCTION.SYNC_FUNCTIONS (
catalog_name => 'OCI_DEMO_CATALOG'
);
END;
/