Exécution de requêtes dynamiques et récupération du résultat dans une variable dans une procédure stockée MySQL
Dans MySQL, vous pouvez générer des requêtes dynamiques dans des procédures stockées pour gérer opérations de données complexes et flexibles. Cet article vous guidera dans la récupération du résultat d'une requête dynamique dans un paramètre OUT.
Considérez la procédure stockée suivante :
CREATE PROCEDURE searchInvoice( OUT numOfRecords INT ) BEGIN DECLARE query1 TEXT; DECLARE query2 TEXT; SET query1 = 'SELECT COUNT(*) AS bla FROM bla bla bla.....'; SET query2 = 'SELECT * FROM bla bla bla....'; -- Dynamically generate the rest of both queries based on IN parameters. -- Here, you want to assign the output of query1 to numOfRecords. SET @Sql = query2; PREPARE STMT FROM @Sql; EXECUTE STMT; DEALLOCATE PREPARE STMT; -- PHP can access the output of query2 here. END
Pour récupérer la sortie de la requête 1 dans le paramètre OUT numOfRecords , vous pouvez utiliser la technique suivante :
SET @outVar = @queryResult;
Pour exemple :
SET @numOfRecords = @query1Result;
Voici un exemple de démonstration :
CREATE PROCEDURE procedure1(IN Param1 VARCHAR(255), OUT Param2 VARCHAR(255), OUT Param3 VARCHAR(255)) BEGIN SET @c2 = ''; SET @c3 = ''; SET @query = 'SELECT column2, column3 INTO @c2, @c3 FROM table1 WHERE column1 = ?'; PREPARE stmt FROM @query; SET @c1 = Param1; EXECUTE stmt USING @c1; DEALLOCATE PREPARE stmt; SET Param2 = @c2; SET Param3 = @c3; END$$
Appel de la procédure et utilisation des variables :
SET @Param1 = 2; SET @Param2 = ''; SET @Param3 = ''; CALL procedure1(@Param1, @Param2, @Param3); SELECT @Param2, @Param3; +---------+---------+ | @Param2 | @Param3 | +---------+---------+ | value3 | value4 | +---------+---------+
En utilisant cette technique, vous pouvez exécuter requêtes dynamiques et récupérez leurs résultats dans les paramètres OUT des procédures stockées MySQL, vous permettant de gérer efficacement des opérations de données complexes.
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!