- Catégories :
Fonctions système (Informations système)
SYSTEM$SET_RETURN_VALUE¶
Définit explicitement la valeur de retour pour une tâche.
Dans un graphique de tâches, une tâche peut appeler cette fonction pour définir une valeur de retour. Une autre tâche qui identifie cette tâche en tant que prédécesseur (à l’aide du mot clé AFTER
dans la définition de tâche) peut récupérer la valeur de retour définie par la tâche prédécesseur à l’aide de SYSTEM$GET_PREDECESSOR_RETURN_VALUE.
Syntaxe¶
SYSTEM$SET_RETURN_VALUE( '<string_expression>' )
Arguments¶
string_expression
Chaîne à définir comme valeur de retour. La taille de la chaîne doit être <= 10 kB (lorsqu’elle est codée en UTF8).
Exemples¶
Créez une tâche qui définit une valeur de retour. Créez une deuxième tâche enfant qui sera exécutée une fois le prédécesseur terminé. La tâche enfant extrait la valeur de retour définie par le prédécesseur (en appelant SYSTEM$GET_PREDECESSOR_RETURN_VALUE) et l’insère dans une ligne de table :
-- create a table to store the return values. create or replace table return_values (str varchar); -- create a task that sets the return value for the task. create task set_return_value warehouse=return_task_wh schedule='1 minute' as call system$set_return_value('The quick brown fox jumps over the lazy dog'); -- create a task that identifies the first task as the predecessor task and retrieves the return value set for that task. create task get_return_value warehouse=return_task_wh after set_return_value as insert into return_values values(system$get_predecessor_return_value()); -- Note that if there are multiple predecessor tasks that are enabled, you must specify the name of the task to retrieve the return value for that task. create task get_return_value_by_pred warehouse=return_task_wh after set_return_value as insert into return_values values(system$get_predecessor_return_value('SET_RETURN_VALUE')); -- resume task (using ALTER TASK ... RESUME). -- wait for task to run on schedule. select distinct(str) from return_values; +-----------------------------------------------+ | STR | +-----------------------------------------------+ | The quick brown fox jumps over the lazy dog | +-----------------------------------------------+ select distinct(RETURN_VALUE) from table(information_schema.task_history()) where RETURN_VALUE is not NULL; +-----------------------------------------------+ | RETURN_VALUE | +-----------------------------------------------+ | The quick brown fox jumps over the lazy dog | +-----------------------------------------------+
Semblable au premier exemple, mais définissez la valeur de retour pour la tâche et récupérez-la en appelant des procédures stockées distinctes :
-- create a table to store the return values.
create or replace table return_values_sp (str varchar);
-- create a stored procedure that sets the return value for the task.
create or replace procedure set_return_value_sp()
returns string
language javascript
execute as caller
as $$
var stmt = snowflake.createStatement({sqlText:`call system$set_return_value('The quick brown fox jumps over the lazy dog');`});
var res = stmt.execute();
$$;
-- create a stored procedure that inserts the return value for the predecessor task into the 'return_values_sp' table.
create or replace procedure get_return_value_sp()
returns string
language javascript
execute as caller
as $$
var stmt = snowflake.createStatement({sqlText:`insert into return_values_sp values(system$get_predecessor_return_value());`});
var res = stmt.execute();
$$;
-- create a task that calls the set_return_value stored procedure.
create task set_return_value_t
warehouse=warehouse1
schedule='1 minute'
as
call set_return_value_sp();
-- create a task that calls the get_return_value stored procedure.
create task get_return_value_t
warehouse=warehouse1
after set_return_value_t
as
call get_return_value_sp();
-- resume task.
-- wait for task to run on schedule.
select distinct(str) from return_values_sp;
+-----------------------------------------------+
| STR |
+-----------------------------------------------+
| The quick brown fox jumps over the lazy dog |
+-----------------------------------------------+
select distinct(RETURN_VALUE)
from table(information_schema.task_history())
where RETURN_VALUE is not NULL;
+-----------------------------------------------+
| RETURN_VALUE |
+-----------------------------------------------+
| The quick brown fox jumps over the lazy dog |
+-----------------------------------------------+