L'exécution de chaînes sous forme de requêtes dynamiques peut être une technique utile dans la programmation de bases de données. Dans MySQL, cette fonctionnalité n'est pas disponible via des méthodes directes comme EXEC ou EXECUTE. Cependant, il existe une solution de contournement en utilisant les instructions PREPARE et EXECUTE.
Pour exécuter une chaîne en tant que requête dans MySQL, vous pouvez utiliser les étapes suivantes :
PREPARE stmt FROM 'INSERT INTO table_name (column1, column2) VALUES (?, ?)';
SET @value1 = 'value1'; SET @value2 = 'value2';
EXECUTE stmt USING @value1, @value2;
DEALLOCATE PREPARE stmt;
Exemple :
L'exemple suivant montre comment exécuter dynamiquement une requête pour insérer plusieurs lignes dans une table :
SET @queryString = ( SELECT CONCAT('INSERT INTO user_group (`group_id`,`user_id`) VALUES ', www.vals) as res FROM ( SELECT GROUP_CONCAT(qwe.asd SEPARATOR ',') as vals FROM ( SELECT CONCAT('(59,', user_id, ')') as asd FROM access WHERE residency = 9 ) as qwe ) as www ); PREPARE stmt FROM @queryString; EXECUTE stmt; DEALLOCATE PREPARE stmt; SET @asd = NULL;
Cet exemple interroge la base de données pour une liste d'ID utilisateur et d'ID de groupe, crée une requête dynamique chaîne pour insérer ces valeurs dans la table user_group, puis exécute la requête dynamique.
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!