Maison >base de données >tutoriel mysql >Comment créer une fonction stockée MySQL qui utilise les données dynamiques d'une table ?
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!