Dans MySQL, il est possible d'exécuter des requêtes impliquant des tables avec des noms attribués dynamiquement. Cette fonctionnalité est utile lorsque vous travaillez avec un ensemble de tables dont les noms doivent être extraits d'une autre source ou dérivés d'une entrée utilisateur.
Un scénario courant dans lequel la sélection dynamique de tables devient nécessaire est celui où le nom de la table est stocké dans une variable. Par exemple, considérons le code suivant :
SET @ID_1 = (SELECT ID FROM `slider` LIMIT 0,1); SET @Cat = (SELECT Category FROM `slider` LIMIT 0,1); select * from @Cat where ID = @ID_1
Ce code tente de sélectionner des lignes d'une table nommée @Cat, où le nom de la table reçoit la valeur d'une variable. Cependant, l'exécution de cette requête dans MySQL entraînera une erreur, car la base de données ne reconnaît pas « @Cat » comme nom de table valide.
Pour surmonter ce problème , il est nécessaire d'utiliser des instructions préparées, qui permettent l'exécution dynamique de requêtes SQL. L'idée de base est de construire la chaîne de requête en fonction des valeurs des variables, puis d'utiliser les instructions PREPARE et EXECUTE pour préparer et exécuter la requête.
Vous trouverez ci-dessous un code révisé qui utilise des instructions préparées pour réaliser une sélection de table dynamique :
SET @s = CONCAT('select * from ', @Cat, ' where ID = ', @ID_1); -- Construct the query string PREPARE stmt1 FROM @s; -- Prepare the statement EXECUTE stmt1; -- Execute the statement DEALLOCATE PREPARE stmt1; -- Deallocate the prepared statement
Dans ce script, la fonction CONCAT() est utilisée pour construire la chaîne de requête en fonction des valeurs des variables @Cat et @ID_1. L'instruction préparée est ensuite créée à l'aide de l'instruction PREPARE et la requête est exécutée avec l'instruction EXECUTE. Enfin, l'instruction préparée est libérée à l'aide de l'instruction DEALLOCATE PREPARE.
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!