Catégories :

DDL pour les fonctions définies par l’utilisateur, les fonctions externes et les procédures stockées

SHOW USER FUNCTIONS

Liste toutes les fonctions définies par l’utilisateur (UDFs) pour lesquelles vous avez des privilèges d’accès. Cette commande peut être utilisée pour lister les UDFs d’une base de données ou d’un schéma spécifié (ou de la base de données/du schéma actuels de la session), ou de l’ensemble de votre compte.

Voir aussi :

SHOW FUNCTIONS , SHOW EXTERNAL FUNCTIONS

Vue FUNCTIONS (Information Schema)

Syntaxe

SHOW USER FUNCTIONS [ LIKE '<pattern>' ]
                    [ IN { ACCOUNT | [ DATABASE ] <db_name> | [ SCHEMA ] <schema_name> } ]

Paramètres

LIKE 'motif'

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%' ...
IN ACCOUNT | [ DATABASE ] nom_bd | [ SCHEMA ] nom_schéma

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 :

Le mot clé DATABASE ou SCHEMA n’est pas nécessaire ; vous pouvez définir la portée en spécifiant uniquement le nom de la base de données ou du schéma. De même, le nom de la base de données ou du schéma n’est pas nécessaire si la session utilise actuellement une base de données :

  • Si DATABASE ou SCHEMA est spécifié sans nom et que la session n’a pas de base de données actuellement utilisée, le paramètre n’a aucun effet sur la sortie.

  • Si SCHEMA est spécifié avec un nom et que la session n’utilise pas de base de données, le nom du schéma doit être entièrement qualifié avec le nom de la base de données (par ex. testdb.testschema).

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).

Notes sur l’utilisation

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

  • La commande retourne un maximum de 10 000 enregistrements pour le type d’objet spécifié, comme dicté par les privilèges d’accès pour le rôle utilisé pour exécuter la commande ; tous les enregistrements au-dessus de la limite de 10 000 enregistrements ne sont pas retournés, même avec un filtre appliqué.

    Pour afficher les résultats pour lesquels il existe plus de 10 000 enregistrements, interrogez la vue correspondante (s’il en existe une) dans Schéma d’information.

  • 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 colonnes et les métadonnées dans les colonnes suivantes :

Colonne

Description

created_on

Horodatage auquel la fonction définie par l’utilisateur (UDF) a été créée.

name

Nom de l” UDF.

schema_name

Nom du schéma dans lequel réside l” UDF.

is_builtin

Si l” UDF est intégré (toujours False pour les UDFs).

is_aggregate

True si l” UDF est une fonction d’agrégation ; false dans les autres cas.

is_ansi

Ne s’applique pas actuellement.

min_num_arguments

Nombre minimum d’arguments vers l” UDF.

max_num_arguments

Nombre maximum d’arguments vers l” UDF.

arguments

Types de données des arguments et de la valeur renvoyée.

description

Description de l” UDF.

catalog_name

Nom de la base de données dans laquelle réside l” UDF.

is_table_function

True si l” UDF est une fonction de table ; false dans les autres cas.

valid_for_clustering

True si l” UDF peut être utilisé dans une expression CLUSTER BY ; false dans les autres cas.

is_secure

True si l” UDF est un UDF sécurisé ; false dans les autres cas.

Exemples

Afficher tous les UDFs que vous avez le privilège d’afficher dans la base de données actuelle :

SHOW USER FUNCTIONS;

---------------------------------+------------------------+-------------------+------------+--------------+---------+-------------------+-------------------+------------------------------------------------------------------------------------------+-----------------------+
           created_on            |          name          |    schema_name    | is_builtin | is_aggregate | is_ansi | min_num_arguments | max_num_arguments |                                        arguments                                         |      description      |
---------------------------------+------------------------+-------------------+------------+--------------+---------+-------------------+-------------------+------------------------------------------------------------------------------------------+-----------------------+
 Wed, 01 Aug 2012 00:00:00 -0700 | GET_COUNTRIES_FOR_USER | TESTDB.TESTSCHEMA | N          | N            | N       | 1                 | 1                 | GET_COUNTRIES_FOR_USER(NUMBER) RETURN TABLE (COUNTRY_CODE VARCHAR, COUNTRY_NAME VARCHAR) | user-defined function |
 Wed, 01 Aug 2012 00:00:00 -0700 | MULTIPLY               | TESTDB.TESTSCHEMA | N          | N            | N       | 2                 | 2                 | MULTIPLY(NUMBER, NUMBER) RETURN NUMBER                                                   | multiply two numbers  |
---------------------------------+------------------------+-------------------+------------+--------------+---------+-------------------+-------------------+------------------------------------------------------------------------------------------+-----------------------+