- À l’aide de SQL
- À l’aide de l’UI et de votre propre code (Public Beta)
Fonctions SQL définies par l’utilisateur
CREATE FUNCTION à partir d’une expression lambda.
Dans cet exemple, nous allons créer une simple fonction exécutable définie par l’utilisateur, isBusinessHours.
La fonction vérifiera si un timestamp donné correspond aux heures ouvrées habituelles et renverra true si c’est le cas, sinon false.
- Connectez-vous à Cloud Console et ouvrez la console SQL
- Écrivez la SQL query suivante pour créer la fonction
isBusinessHours:
- Exécutez ce qui suit pour tester l’UDF que vous venez de créer :
- Vous pouvez utiliser la commande
DROP FUNCTIONpour supprimer l’UDF que vous venez de créer :
- Les paramètres de session (définis via l’instruction
SET) ne sont pas transmis au contexte d’exécution des UDFs - Les paramètres du profil utilisateur ne sont pas hérités par les UDFs
- Les paramètres au niveau de la requête ne s’appliquent pas lors de l’exécution des UDFs
Fonctions définies par l’utilisateur créées via l’UI
isBusinessHours, qui vérifie si un timestamp donné se situe dans les heures ouvrées habituelles.
Nous l’avons précédemment créée en SQL, mais cette fois, nous allons la créer en Python et la configurer via l’UI.
Créer le fichier Python
Créez un nouveau fichiermain.py localement :requirements.txt, et ClickHouse Cloud les installera pour vous. Vous pouvez aussi inclure directement les dépendances dans l’archive ZIP, mais vous devrez alors fournir les paquets mis en cache pour les deux architectures CPU ; requirements.txt reste donc la solution la plus simple. Par exemple :ClickHouse Cloud s’attend à trouver
main.py dans l’archive zip que vous téléverserez via l’UI à l’étape suivante.
Si vous donnez un autre nom au fichier, une erreur se produira.Dépendances regroupées et fichiers locaux
Pour inclure les paquets de dépendances et tout autre fichier local (par exemple, des fichiers wheel, des fichiers de configuration ou des fichiers de données), placez-les dans le même répertoire quemain.py et requirements.txt. Lorsque vous créez l’archive ZIP, incluez tous les fichiers :os.path.dirname(os.path.abspath(__file__)). Cela renvoie le chemin absolu du répertoire où se trouve votre main.py dans l’archive ZIP, ce qui vous permet d’accéder aux autres fichiers inclus :- Accéder aux fichiers de configuration inclus avec votre UDF
- Charger des packages wheel pour des dépendances personnalisées
- Référencer des scripts supplémentaires ou des fichiers de données
Créer une UDF via l’UI
- Depuis la page d’accueil de la console Cloud, cliquez sur le nom de votre organisation dans le menu en bas à gauche.
- Sélectionnez Fonctions définies par l’utilisateur dans le menu.
- Sur la page des fonctions définies par l’utilisateur, cliquez sur Configurer une UDF. Un panneau de configuration s’ouvre sur la droite de l’écran.
- Saisissez un nom de fonction. Pour cet exemple, utilisez
isBusinessHours. - Sélectionnez un type de fonction, Executable pool ou Executable :
- Executable pool : un pool de processus persistants est maintenu, et un processus est prélevé dans ce pool pour effectuer les lectures.
- Executable : le script s’exécute à chaque requête.
- Pour cet exemple, utilisez les paramètres par défaut. Pour obtenir la liste complète des paramètres de configuration, consultez Executable user-defined functions.
- Cliquez sur Parcourir le fichier pour téléverser le fichier
.zipcréé au début de ce tutoriel. - Ajoutez un nouvel argument. Pour cet exemple, ajoutez un argument
timestampde typeDateTime. - Sélectionnez un type de retour. Pour cet exemple, sélectionnez
Bool. - Cliquez sur Créer une UDF. Une boîte de dialogue affiche l’état actuel du build.
- En cas de problème, l’état devient error.
- Sinon, l’état passe de building à provisioning. Votre service doit être actif pour terminer le provisionnement. Si votre service est inactif, cliquez sur Réveiller le service dans le panneau Détails de l’UDF à côté du nom du service.
- Une fois l’opération terminée, l’état devient deployed.
Testez votre UDF
- revenez à la page d’accueil de la SQL Console en cliquant sur Settings - return to your service view dans le coin supérieur gauche de la page
- cliquez sur SQL Console dans le menu de gauche
- saisissez la requête suivante :
Créer une nouvelle version
Pour modifier le code d’une UDF, créez une nouvelle version. Le panneau Edit sert uniquement à gérer les services auxquels une UDF est affectée ; y téléverser un fichier ne remplacera pas le code déployé.- Depuis la page d’accueil de la console Cloud, cliquez sur le nom de votre organisation dans le menu en bas à gauche.
- Sélectionnez User-defined functions dans le menu.
- Cliquez sur les trois points sous Actions pour la UDF
isBusinessHours, puis sur Create new version - Téléversez un fichier zip contenant le code modifié, ou modifiez les paramètres, puis cliquez sur Create new version