SHOW USER PROCEDURES¶
Répertorie toutes les procédures définies par l’utilisateur pour lesquelles vous disposez de privilèges d’accès. Utilisez cette commande pour répertorier les procédures définies par l’utilisateur d’une base de données ou d’un schéma spécifié(e) (ou la base de données/le schéma en cours pour la session), d’une application ou de l’ensemble de votre compte.
Pour une commande permettant de répertorier toutes les procédures, y compris les procédures intégrées et celles définies par l’utilisateur, voir SHOW PROCEDURES.
- Voir aussi :
SHOW PROCEDURES, Vue PROCEDURES (Information Schema), Vue PROCEDURES (Account Usage), SHOW USER PROCEDURES
Syntaxe¶
SHOW USER PROCEDURES [ LIKE '<pattern>' ]
[ IN
{
ACCOUNT |
DATABASE |
DATABASE <database_name> |
SCHEMA |
SCHEMA <schema_name> |
<schema_name>
APPLICATION <application_name> |
APPLICATION PACKAGE <application_package_name> |
}
]
Paramètres¶
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 ... ]Spécifie de manière facultative la portée de la commande. Spécifie l’un des éléments suivants :
ACCOUNTRenvoie les enregistrements pour l’ensemble du compte.
DATABASE, .DATABASE db_nameRenvoie les enregistrements pour la base de données en cours d’utilisation ou pour une base de données spécifiée (
db_name).Si vous spécifiez
DATABASEsansdb_nameet qu’aucune base de données n’est utilisée, le mot-clé n’a aucun effet sur la sortie.Note
L’utilisation de commandes SHOW sans clause
INdans un contexte de base de données peut donner moins de résultats que prévu.Les objets portant le même nom ne sont affichés qu’une seule fois si aucune clause
INn’est utilisée. Par exemple, si la tablet1se trouve dansschema1et la tablet1dansschema2et si elles sont toutes les deux dans le champ d’application du contexte de base de données que vous avez spécifié (c’est-à-dire, si la base de données que vous avez sélectionnée est le parent deschema1et deschema2), SHOW TABLES n’affiche qu’une seule des tablest1.SCHEMA, .SCHEMA schema_nameRenvoie les enregistrements pour le schéma en cours d’utilisation ou un schéma spécifié (
schema_name).SCHEMAest facultatif si une base de données est utilisée ou si vous spécifiez leschema_namecomplet (par exemple,db.schema).Si aucune base de données n’est utilisée, spécifier
SCHEMAn’a aucun effet sur la sortie.
APPLICATION application_name, .APPLICATION PACKAGE application_package_nameRenvoie les enregistrements pour l”Snowflake Native App nommée ou un paquet d’application.
Si vous omettez
IN ..., la portée de la commande dépend de l’existence ou non d’une base de données en cours d’utilisation dans la session :If a database is currently in use, the command returns the objects you have privileges to view in the database. This has the same effect as specifying
IN DATABASE.If no database is currently in use, the command returns the objects you have privileges to view in your account. This has the same effect as specifying
IN ACCOUNT.
Sortie¶
La sortie de la commande répertorie les propriétés et les métadonnées de la procédure utilisateur dans les colonnes suivantes :
Colonne |
Description |
|---|---|
|
Horodatage de création de la procédure. |
|
Nom de la procédure. |
|
Nom du schéma dans lequel la procédure existe. |
|
|
|
Ne s’applique pas actuellement. |
|
Ne s’applique pas actuellement. |
|
Nombre minimal d’arguments de la procédure. |
|
Nombre maximal d’arguments de la procédure. |
|
Types de données des arguments et de la valeur renvoyée. Pour les procédures stockées d’exécution de scripts Snowflake, |
|
Description de la procédure. |
|
Nom de la base de données dans laquelle la procédure existe. |
|
|
|
|
|
|
|
Mappage des valeurs secrètes spécifiées par le paramètre SECRETS de la procédure, où les clés de mappage sont des noms de variables secrètes et les valeurs de mappage sont des noms d’objets secrets. |
|
Noms d”intégrations de l’accès externe spécifiées par le paramètre EXTERNAL_ACCESS_INTEGRATION de la procédure. |
Notes sur l’utilisation¶
La commande ne nécessite pas l’exécution d’un entrepôt en cours d’exécution.
La commande ne renvoie que les objets pour lesquels le rôle actuel de l’utilisateur s’est vu accorder au moins un privilège d’accès.
Le privilège d’accès MANAGE GRANTS permet implicitement à son titulaire de voir tous les objets du compte. Par défaut, seuls l’administrateur du compte (utilisateurs avec le rôle ACCOUNTADMIN) et l’administrateur de sécurité (utilisateurs avec le rôle SECURITYADMIN) ont le privilège MANAGE GRANTS.
Pour post-traiter la sortie de cette commande, vous pouvez utiliser la syntaxe opérateur de canal (
->>) ou la fonction RESULT_SCAN. Les deux constructions traitent la sortie comme un jeu de résultats que vous pouvez interroger.For example, you can use the pipe operator or RESULT_SCAN function to select specific columns from the SHOW command output or filter the rows.
When you refer to the output columns, use double-quoted identifiers for the column names. For example, to select the output column
type, specifySELECT "type".You must use double-quoted identifiers because the output column names for SHOW commands are in lowercase. The double quotes ensure that the column names in the SELECT list or WHERE clause match the column names in the SHOW command output that was scanned.
La commande renvoie un maximum de dix mille enregistrements pour le type d’objet spécifié, conformément aux privilèges d’accès du rôle utilisé pour exécuter la commande. Aucun enregistrement au-delà de la limite de dix mille enregistrements n’est renvoyé, même si un filtre a été appliqué.
Pour afficher les résultats pour lesquels il existe plus de dix mille enregistrements, interrogez la vue correspondante (le cas échéant) dans Schéma d’information de Snowflake.
Exemples¶
Afficher les procédures que vous avez le privilège de voir dans le schéma actuel et dont le nom commence par GET_ :
SHOW USER PROCEDURES LIKE 'GET_%' IN SCHEMA;-------------------------------+-----------------+-------------+------------+--------------+---------+-------------------+-------------------+---------------------------------------+------------------------+--------------+-------------------+----------------------+-----------+---------+------------------------------+ created_on | name | schema_name | is_builtin | is_aggregate | is_ansi | min_num_arguments | max_num_arguments | arguments | description | catalog_name | is_table_function | valid_for_clustering | is_secure | secrets | external_access_integrations | -------------------------------+-----------------+-------------+------------+--------------+---------+-------------------+-------------------+---------------------------------------+------------------------+--------------+-------------------+----------------------+-----------+---------+------------------------------+ 2023-01-27 15:01:13.862 -0800 | GET_FILE | PUBLIC | N | N | N | 1 | 1 | GET_FILE(VARCHAR) RETURN VARCHAR | user-defined procedure | BOOKS_DB | N | N | N | | | 2023-03-23 10:38:10.423 -0700 | GET_NUM_RESULTS | PUBLIC | N | N | N | 1 | 1 | GET_NUM_RESULTS(VARCHAR) RETURN FLOAT | user-defined procedure | BOOKS_DB | N | N | N | | | 2023-03-23 09:47:55.840 -0700 | GET_RESULTS | PUBLIC | N | N | N | 1 | 1 | GET_RESULTS(VARCHAR) RETURN TABLE () | user-defined procedure | BOOKS_DB | Y | N | N | | | -------------------------------+-----------------+-------------+------------+--------------+---------+-------------------+-------------------+---------------------------------------+------------------------+--------------+-------------------+----------------------+-----------+---------+------------------------------+