SHOW TASKS

Liste les tâches pour lesquelles vous avez des privilèges d’accès. La commande peut être utilisée pour répertorier les tâches de la base de données ou du schéma actuel/spécifié ou pour l’ensemble de votre compte.

La sortie renvoie les métadonnées et les propriétés des tâches, classées lexicographiquement par nom de base de données, de schéma et de tâche (voir Sortie dans ce chapitre pour lire la description des colonnes de sortie). Ceci est important à noter si vous souhaitez filtrer les résultats à l’aide des filtres fournis.

Voir aussi :

CREATE TASK , ALTER TASK , DROP TASK , DESCRIBE TASK

Syntaxe

SHOW [ TERSE ] TASKS [ LIKE '<pattern>' ]
                     [ IN { ACCOUNT | DATABASE [ <db_name> ] | [ SCHEMA ] [ <schema_name> ] } ]
                     [ STARTS WITH '<name_string>' ]
                     [ ROOT ONLY ]
                     [ LIMIT <rows> [ FROM '<name_string>' ] ]
Copy

Paramètres

TERSE

Retourne seulement un sous-ensemble des colonnes de sortie :

  • created_on

  • name

  • type (affiche NULL pour tous les enregistrements de tâches)

  • database_name

  • schema_name

  • schedule

LIKE 'pattern'

(Facultatif) Filtre la sortie de commande par nom d’objet. Le filtre utilise une concordance de motif insensible à la casse avec prise en charge des caractères génériques SQL (% et _).

Par exemple, les motifs suivants donnent les mêmes résultats :

... LIKE '%testing%' ...
... LIKE '%TESTING%' ...

. Par défaut : aucune valeur (aucun filtrage n’est appliqué à la sortie).

IN ACCOUNT | DATABASE [ db_name ] | SCHEMA [ schema_name ]

(Facultatif) Spécifie la portée de la commande, qui détermine si la commande liste les enregistrements uniquement pour la base de données ou le schéma actuel/spécifié, ou pour l’ensemble de votre compte.

Si vous spécifiez le mot clé ACCOUNT, la commande récupère les enregistrements de tous les schémas de toutes les bases de données du compte courant.

Si vous spécifiez le mot clé DATABASE, alors :

  • Si vous spécifiez un db_name, la commande récupère les enregistrements de tous les schémas de la base de données spécifiée.

  • Si vous ne spécifiez pas un db_name, alors :

    • S’il existe une base de données actuelle, la commande récupère les enregistrements de tous les schémas de la base de données actuelle.

    • S’il n’y a pas de base de données actuelle, la commande récupère les enregistrements de toutes les bases de données et de tous les schémas du compte.

Si vous spécifiez le mot clé SCHEMA, alors :

  • Si vous spécifiez un nom de schéma qualifié (par exemple my_database.my_schema), la commande récupère les enregistrements de la base de données et du schéma spécifiés.

  • Si vous spécifiez un schema_name non qualifié, alors :

    • S’il existe une base de données actuelle, la commande récupère les enregistrements du schéma spécifié dans la base de données actuelle.

    • S’il n’y a pas de base de données actuelle, la commande affiche l’erreur SQL compilation error: Object does not exist, or operation cannot be performed.

  • Si vous ne spécifiez pas un schema_name, alors :

    • S’il existe une base de données actuelle, alors :

      • S’il existe un schéma actuel, la commande récupère les enregistrements pour le schéma actuel dans la base de données actuelle.

      • S’il n’y a pas de schéma actuel, la commande récupère les enregistrements de tous les schémas de la base de données actuelle.

    • S’il n’y a pas de base de données actuelle, la commande récupère les enregistrements de toutes les bases de données et de tous les schémas du compte.

Par défaut : dépend si la session dispose actuellement d’une base de données en cours d’utilisation :

  • Base de données : DATABASE est la valeur par défaut (c’est-à-dire que la commande renvoie les objets que vous pouvez visualiser dans la base de données).

  • Aucune base de données : ACCOUNT est la valeur par défaut (c’est-à-dire que la commande renvoie les objets que vous pouvez visualiser dans votre compte).

STARTS WITH 'name_string'

(Facultatif) Filtre la sortie de commande en fonction des caractères qui apparaissent au début du nom de l’objet. La chaîne doit être délimitée par des guillemets simples et est sensible à la casse.

Par exemple, les chaînes suivantes renvoient des résultats différents :

... STARTS WITH 'B' ...
... STARTS WITH 'b' ...

. Par défaut : aucune valeur (aucun filtrage n’est appliqué à la sortie)

ROOT ONLY

Filtre la sortie de la commande pour ne retourner que les tâches racines (tâches sans prédécesseurs).

LIMIT rows [ FROM 'name_string' ]

(Facultatif) Limite le nombre maximum de lignes retournées, tout en permettant la « pagination » des résultats. Le nombre réel de lignes renvoyées peut être inférieur à la limite spécifiée. Par exemple, le nombre d’objets existants est inférieur à la limite spécifiée.

La sous-clause facultative FROM 'name_string' sert effectivement de « curseur » pour les résultats. Ceci permet de récupérer le nombre spécifié de lignes suivant la première ligne dont le nom d’objet correspond à la chaîne spécifiée :

  • La chaîne doit être délimitée par des guillemets simples et est sensible à la casse.

  • La chaîne n’a pas besoin d’inclure le nom complet de l’objet ; les noms partiels sont pris en charge.

Par défaut : aucune valeur (aucune limite n’est appliquée à la sortie)

Note

Pour les commandes SHOW qui prennent en charge les clauses FROM 'name_string' et STARTS WITH 'name_string', vous pouvez combiner ces deux clauses dans la même instruction. Cependant, les deux conditions doivent être remplies ou elles s’annulent mutuellement et aucun résultat n’est renvoyé.

De plus, les objets sont retournés dans l’ordre lexicographique par nom, donc FROM 'name_string' ne retourne que les lignes ayant une valeur lexicographique plus élevée que les lignes retournées par STARTS WITH 'name_string'

Par exemple :

  • ... STARTS WITH 'A' LIMIT ... FROM 'B' ne donnerait aucun résultat.

  • ... STARTS WITH 'B' LIMIT ... FROM 'A' ne donnerait aucun résultat.

  • ... STARTS WITH 'A' LIMIT ... FROM 'AB' donnerait des résultats (si des lignes correspondent aux chaînes d’entrée).

Notes sur l’utilisation

  • Renvoie uniquement les lignes du propriétaire d’une tâche (c’est-à-dire le rôle avec le privilège OWNERSHIP sur une tâche) ou un rôle avec le privilège MONITOR ou OPERATE sur une tâche.

  • L’exécution de la commande ne nécessite pas l’exécution d’un entrepôt en cours d’exécution.

  • La valeur pour LIMIT rows ne peut pas dépasser 10000. Si LIMIT rows est omis, la commande entraîne une erreur si le jeu de résultats est supérieur à 10 000 lignes.

  • Pour post-traiter la sortie de cette commande, vous pouvez utiliser la fonction RESULT_SCAN qui traite la sortie comme une table qui peut être interrogée.

Sortie

La sortie de commande fournit les propriétés des tâches et les métadonnées dans les colonnes suivantes :

Nom de la colonne

Description

created_on

Date et heure de création de la tâche.

name

Nom de la tâche.

id

Identificateur unique pour chaque tâche. Notez que recréer une tâche (en utilisant CREATE OR REPLACE TASK) crée essentiellement une nouvelle tâche, qui a un nouveau ID.

database_name

Base de données dans laquelle la tâche est stockée.

schema_name

Schéma dans lequel la tâche est stockée.

propriétaire

Rôle qui possède la tâche (c.-à-d. qui dispose du privilège OWNERSHIP sur la tâche)

commentaire

Commentaire pour la tâche.

entrepôt

Entrepôt virtuel qui fournit les ressources requises pour exécuter la tâche.

schedule

Planifiez l’exécution de la tâche. Affiche NULL si aucune planification n’est spécifiée.

predecessors

Tableau JSON de toutes les tâches identifiées dans le paramètre AFTER de la tâche (c’est-à-dire les tâches prédécesseurs). Lorsqu’elles sont exécutées avec succès jusqu’à leur terme, ces tâches déclenchent la tâche en cours. Les noms des tâches individuelles dans le tableau sont entièrement qualifiés (c’est-à-dire qu’ils incluent les noms de la base de données et du schéma du conteneur). . . Affiche un tableau vide si la tâche n’a pas de prédécesseur.

state

« Démarré » ou « Suspendu » en fonction de l’état actuel de la tâche.

definition

Instructions SQL exécutées lors de l’exécution de la tâche.

condition

Condition spécifiée dans la clause WHEN pour la tâche.

allow_overlapping_execution

Pour les tâches racines d’un graphique de tâches, affiche TRUE si le chevauchement de l’exécution du graphique de tâches est explicitement autorisé. Pour les tâches enfants dans un graphique de tâches, affiche NULL.

error_integration

Nom de l’intégration de notification utilisée pour accéder à Amazon Simple Notification Service (SNS), Google Pub/Sub, ou Microsoft Azure Event Grid afin de relayer les notifications d’erreur pour la tâche.

last_committed_on

Horodatage de la dernière version définie pour la tâche. Si aucune version n’a été définie (c’est-à-dire si la tâche n’a pas été reprise ou exécutée manuellement après sa création), la valeur est NULL.

last_suspended_on

Horodatage de la dernière suspension de la tâche. Affiche les horodatages des tâches racines et des tâches enfants. Si la tâche n’a pas encore été suspendue, la valeur est NULL.

owner_role_type

Type de rôle qui possède l’objet, soit ROLE ou DATABASE_ROLE. . Si une Snowflake Native App est propriétaire de l’objet, la valeur est APPLICATION. . Snowflake renvoie NULL si vous supprimez l’objet, car un objet supprimé n’a pas de rôle propriétaire.

config

Pour la tâche racine d’un graphique de tâches, affiche la configuration si elle est présente, sinon, NULL. Pour les tâches enfants dans un graphique de tâches, affiche NULL.

budget

Nom du budget si l’objet est contrôlé par un budget. sinon, NULL.

last_suspended_on

Affiche la raison pour laquelle la tâche a été suspendue. Les raisons possibles sont les suivantes :

  • USER_SUSPENDED : l’utilisateur a suspendu la tâche en exécutant la commande alter task <nom> suspend.

  • SCHEMA_OR_DATABASE_DELETED: Le schéma ou la base de données de la tâche a été supprimé.

  • GRANT_OWNERSHIP: L’utilisateur a transféré la propriété de la tâche à un autre rôle en exécutant la commande grant ownership.

  • SUSPENDED_DUE_TO_ERRORS: La tâche a échoué un certain nombre de fois consécutives et a été suspendue. Vous pouvez définir le paramètre SUSPEND_TASK_AFTER_NUM_FAILURES pour le nombre d’échecs requis pour suspendre cette tâche.

  • CHILD_BECAME_ROOT : la tâche était auparavant une tâche enfant dans un graphique de tâches, mais tous les prédécesseurs de la tâche enfant ont été supprimés et la tâche enfant est devenue une tâche racine.

  • FINALIZER_BECAME_ROOT : la tâche était auparavant une tâche de finalisation dans un graphique de tâches, mais la finalisation a été supprimée et la tâche est devenue une tâche racine.

  • MATCHING_OWNER_NOT_FOUND: Lors de la réplication de la tâche, le rôle propriétaire de la tâche n’a pas été trouvé dans la base de données secondaire.

Affiche NULL si la tâche n’a jamais été suspendue ou si la tâche a été suspendue pour la dernière fois avant que la colonne ne soit introduite avec Bundle 2023_08 (activé de manière générale).

task_relations

Alternative pour la colonne predecessors. Affiche un tableau JSON de toutes les tâches identifiées dans le paramètre AFTER de la tâche (c’est-à-dire les tâches prédécesseurs). Lorsqu’elles sont exécutées avec succès jusqu’à leur terme, ces tâches déclenchent la tâche en cours. Les noms des tâches individuelles dans le tableau sont entièrement qualifiés (c’est-à-dire qu’ils incluent les noms de la base de données et du schéma du conteneur). . . Affiche un tableau vide si la tâche n’a pas de prédécesseur.

Pour plus d’informations sur les propriétés qui peuvent être spécifiées pour une tâche, voir CREATE TASK.

Exemples

Afficher toutes les tâches dont le nom commence par line que vous avez les privilèges d’afficher dans le schéma tpch.public :

SHOW TASKS LIKE 'line%' IN tpch.public;
Copy

Afficher toutes les tâches que vous avez le privilège d’afficher dans le schéma tpch.public :

SHOW TASKS IN tpch.public;
Copy