Je regarde les procédures stockées et la fonction MySQL. Quelle est la vraie différence?
Ils semblent similaires, mais une fonction a plus de limites.
Je me trompe probablement, mais il semble qu'une procédure stockée peut tout faire et plus une fonction stockée peut. Pourquoi / quand utiliserais-je une procédure par rapport à une fonction?
mysql
stored-procedures
sql-function
Anonyme
la source
la source
La différence la plus générale entre les procédures et les fonctions est qu'elles sont invoquées différemment et à des fins différentes:
La syntaxe de la création de routine diffère quelque peu pour les procédures et les fonctions:
Les fonctions renvoient une valeur, il doit donc y avoir une clause RETURNS dans une définition de fonction pour indiquer le type de données de la valeur de retour. En outre, il doit y avoir au moins une instruction RETURN dans le corps de la fonction pour renvoyer une valeur à l'appelant. RETURNS et RETURN n'apparaissent pas dans les définitions de procédure.
Pour appeler une procédure stockée, utilisez le
CALL statement
. Pour appeler une fonction stockée, faites-y référence dans une expression. La fonction renvoie une valeur lors de l'évaluation de l'expression.Une procédure est appelée à l'aide d'une instruction CALL et ne peut renvoyer des valeurs qu'à l'aide de variables de sortie. Une fonction peut être appelée depuis l'intérieur d'une instruction comme n'importe quelle autre fonction (c'est-à-dire en invoquant le nom de la fonction) et peut renvoyer une valeur scalaire.
La spécification d'un paramètre comme IN, OUT ou INOUT n'est valide que pour une PROCEDURE. Pour une FUNCTION, les paramètres sont toujours considérés comme des paramètres IN.
Si aucun mot clé n'est donné avant un nom de paramètre, il s'agit d'un paramètre IN par défaut. Les paramètres des fonctions stockées ne sont pas précédés de IN, OUT ou INOUT. Tous les paramètres de fonction sont traités comme des paramètres IN.
Pour définir une procédure ou une fonction stockée, utilisez respectivement CREATE PROCEDURE ou CREATE FUNCTION:
Une extension MySQL pour les procédures stockées (pas les fonctions) est qu'une procédure peut générer un jeu de résultats, voire plusieurs jeux de résultats, que l'appelant traite de la même manière que le résultat d'une instruction SELECT. Cependant, le contenu de ces ensembles de résultats ne peut pas être utilisé directement dans l'expression.
Les routines stockées (faisant référence à la fois aux procédures stockées et aux fonctions stockées) sont associées à une base de données particulière, tout comme les tables ou les vues. Lorsque vous supprimez une base de données, toutes les routines stockées dans la base de données sont également supprimées.
Les procédures et fonctions stockées ne partagent pas le même espace de noms. Il est possible d'avoir une procédure et une fonction avec le même nom dans une base de données.
Dans les procédures stockées, le SQL dynamique peut être utilisé mais pas dans les fonctions ou les déclencheurs.
Quelques différences plus intéressantes entre FUNCTION et STORED PROCEDURE:
( Ce point est copié à partir d'un article de blog . ) La procédure stockée est un plan d'exécution précompilé alors que les fonctions ne le sont pas. Fonction analysée et compilée au moment de l'exécution. Procédures stockées, stockées sous forme de pseudo-code dans la base de données, c'est-à-dire sous forme compilée.
( Je ne suis pas sûr pour ce point. )
La procédure stockée a la sécurité et réduit le trafic réseau et nous pouvons également appeler la procédure stockée dans n'importe quel non. des applications à la fois. référence
Les fonctions sont normalement utilisées pour les calculs où les procédures sont normalement utilisées pour exécuter la logique métier.
Les fonctions ne peuvent pas affecter l'état de la base de données (les instructions qui effectuent une validation ou une annulation explicite ou implicite sont interdites dans la fonction) alors que les procédures stockées peuvent affecter l'état de la base de données en utilisant la validation, etc.
référence: J.1. Restrictions sur les routines et les déclencheurs stockés
Les fonctions ne peuvent pas utiliser les instructions FLUSH , contrairement aux procédures stockées.
Les fonctions stockées ne peuvent pas être récursives alors que les procédures stockées peuvent l'être. Remarque: les procédures stockées récursives sont désactivées par défaut, mais peuvent être activées sur le serveur en définissant la variable système du serveur max_sp_recursion_depth sur une valeur différente de zéro. Voir Section 5.2.3, «Variables système» , pour plus d'informations.
Dans une fonction ou un déclencheur stocké, il n'est pas permis de modifier une table qui est déjà utilisée (pour la lecture ou l'écriture) par l'instruction qui a appelé la fonction ou le déclencheur. Bon exemple: comment mettre à jour la même table lors de la suppression dans MYSQL?
Remarque : bien que certaines restrictions s'appliquent normalement aux fonctions et déclencheurs stockés, mais pas aux procédures stockées, ces restrictions s'appliquent aux procédures stockées si elles sont appelées à partir d'une fonction stockée ou d'un déclencheur. Par exemple, bien que vous puissiez utiliser FLUSH dans une procédure stockée, une telle procédure stockée ne peut pas être appelée à partir d'une fonction stockée ou d'un déclencheur.
la source
Une différence significative est que vous pouvez inclure une fonction dans vos requêtes SQL, mais les procédures stockées ne peuvent être appelées qu'avec l'
CALL
instruction:Exemple UDF:
Exemple de Sproc:
la source
RETURNS CHAR(50) DETERMINISTIC
?RETURNS CHAR(50)
indique quel type de données sera retourné. LeRETURN CONCAT(...
sont les données qui sont renvoyées. Les deux sont nécessaires. LeDETERMINISTIC
est nécessaire pour indiquer que les données sous-jacentes ne seront pas modifiées.Une fonction stockée peut être utilisée dans une requête. Vous pouvez ensuite l'appliquer à chaque ligne ou dans une clause WHERE.
Une procédure est exécutée à l'aide de la requête CALL.
la source
La procédure stockée peut être appelée récursivement mais la fonction stockée ne peut pas
la source