Une fonction définie par l’utilisateur (UDF) peut retourner une valeur scalaire ou une valeur de type table. Une valeur scalaire renvoyée correspond généralement au paramètre de sortie d’une procédure stockée. Mais une fonction UDF nécessite la déclaration de ce type de données dans sa clause RETURN. La fonction se sert
Trois fonctions UDF.
de cette clause pour retourner une valeur à l’application appelante. Vous pouvez, en option, passer un ou plusieurs paramètres à une fonction UDF.
Comme ce type de fonction ne peut retourner qu’une seule valeur, il en faut trois pour accomplir la même opération qu’avec la procédure stockée upDiscontinuedProducts. Dans le contexte de notre application, la procédure stockée est plus robuste, mais son code est plus complexe que celui de chacune des trois fonctions UDF individuelles. Par ailleurs, vous pouvez référencer la valeur de retour d’une fonction UDF renvoyant une table dans une clause FROM. En revanche, le langage T-SQL ne gère pas le référencement de l’ensemble de résultats d’une procédure stockée dans une clause FROM.
Le listing 2 présente la première fonction UDF, intitulée ufProductsInCategory, laquelle renvoie le nombre total de lignes de la table Products correspondant à la valeur de paramètre @CategoryID passée par une application appelante à la fonction UDF. Le code du listing commence par supprimer toute version antérieure de l’UDF. Comme les procédures stockées et fonctions UDF peuvent appliquer un code identique pour supprimer un objet existant antérieurement, il est judicieux de les différencier en leur attribuant des noms distincts.
Le code pour la deuxième fonction UDF, ufDiscontinuedProductsInCategory, est pratiquement identique au code du listing 2, mais cette fonction renvoie un décompte se limitant aux produits arrêtés dans une catégorie. Pour créer la fonction UDF ufDiscontinuedProductsInCategory, changez simplement les références de nom dans les instructions DROP et CREATE, et remplacez l’instruction SELECT du listing 2 par le code suivant :
SELECT COUNT(*) FROM Northwind.dbo.Products AS np WHERE np.CategoryID = @CategoryID AND Discontinued = 1
Le listing 3 présente la troisième fonction UDF, ufDiscontinuedProductRowsInCategory, dont la valeur est du type table. Elle renvoie un ensemble de lignes référençables via la clause FROM d’une instruction SELECT. Notez que la clause RETURN de la fonction UDF spécifie un type de données table. Cette clause inclut une instruction SELECT, qui remplit la variable table et qui est identique à l’instruction SELECT de la procédure stockée upDiscontinuedProducts.
Téléchargez cette ressource
Guide de Threat Intelligence contextuelle
Ce guide facilitera l’adoption d’une Threat Intelligence - renseignement sur les cybermenaces, cyberintelligence - adaptée au "contexte", il fournit des indicateurs de performance clés (KPI) pour progresser d' une posture défensive vers une approche centrée sur l’anticipation stratégique
Les articles les plus consultés
Les plus consultés sur iTPro.fr
- Asys accélère sur la planification intelligente avec l’acquisition de m-work
- Computex 2026 : 5 signaux forts à retenir
- Vers l’Industrie 5.0 : quand l’IA agentique change la donne
- Ready For IT 2026 : IA industrialisée, deepfakes et Prix Start-up au cœur des enjeux
Articles les + lus
Computex 2026 : 5 signaux forts à retenir
La chaîne d’approvisionnement, point de rupture récurent du SI
Microsoft Build 2026 : contre-offensive des modèles maison face à OpenAI et Anthropic
Rhea1 : SiPearl allume le CPU européen le plus ambitieux pour le HPC et l’IA souveraine
Analyse Patch Tuesday Mai 2026
À la une de la chaîne Tech
- Computex 2026 : 5 signaux forts à retenir
- La chaîne d’approvisionnement, point de rupture récurent du SI
- Microsoft Build 2026 : contre-offensive des modèles maison face à OpenAI et Anthropic
- Rhea1 : SiPearl allume le CPU européen le plus ambitieux pour le HPC et l’IA souveraine
- Analyse Patch Tuesday Mai 2026
