Maison >base de données >tutoriel mysql >Comment créer une fonction stockée MySQL qui utilise les données dynamiques d'une table ?

Comment créer une fonction stockée MySQL qui utilise les données dynamiques d'une table ?

PHPz
PHPzavant
2023-09-18 13:37:031414parcourir

我们如何创建一个使用表中动态数据的 MySQL 存储函数?

Les fonctions stockées MySQL peuvent référencer des tables, mais elles ne peuvent pas utiliser d'instructions qui renvoient des ensembles de résultats. Nous pouvons donc dire qu’il n’existe pas de requête SELECT qui renvoie un jeu de résultats. Mais nous pouvons utiliser SELECT INTO pour résoudre ce problème. Par exemple, nous créons une fonction « Avg_marks » qui calcule le score moyen en utilisant les données dynamiques d'une table appelée « Student_marks » (avec les enregistrements suivants).

mysql> Select * from Student_marks;
+-------+------+---------+---------+---------+
| Name  | Math | English | Science | History |
+-------+------+---------+---------+---------+
| Raman |   95 |      89 |      85 |      81 |
| Rahul |   90 |      87 |      86 |      81 |
+-------+------+---------+---------+---------+
2 rows in set (0.00 sec)

mysql> DELIMITER //
mysql> Create Function Avg_marks(S_name Varchar(50))
    -> RETURNS INT
    -> DETERMINISTIC
    -> BEGIN
    -> DECLARE M1,M2,M3,M4,avg INT;
    -> SELECT Math,English,Science,History INTO M1,M2,M3,M4 FROM Student_marks W
HERE Name = S_name;
    -> SET avg = (M1+M2+M3+M4)/4;
    -> RETURN avg;
    -> END //
Query OK, 0 rows affected (0.01 sec)

mysql> DELIMITER ;
mysql> Select Avg_marks('Raman') AS 'Raman_Marks';
+-------------+
| Raman_Marks |
+-------------+
|          88 |
+-------------+
1 row in set (0.07 sec)

mysql> Select Avg_marks('Rahul') AS 'Raman_Marks';
+-------------+
| Raman_Marks |
+-------------+
|          86 |
+-------------+
1 row in set (0.00 sec)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:Cinquième forme normale (5NF)Article suivant:Cinquième forme normale (5NF)