Requêtes mises ou non en mémoire tampon
Les requêtes utilisent par défaut le mode Mémoire tampon.
Cela signifie que le résultat des requêtes est immédiatement
transféré du serveur MySQL à PHP et sont ensuite conservé dans la mémoire
du processus PHP. Cela permet des opérations complémentaires
comme compter le nombre de résultat, et déplacer le
pointeur de résultat actuel. Il permet également d'exécuter des
requêtes supplémentaires sur la même connexion tout en travaillant
sur le jeu de résultats. L'inconvénient de la mise en mémoire
tampon est que des jeux de résultats importants peuvent demander
beaucoup plus de mémoire. La mémoire restera occupée jusqu'à ce
que toutes les références sur les jeux de résultats soient
désactivées ou que les jeux de résultats soient explicitement
libérés, ce qui arrive de manière automatique à la fin du
processus. La terminologie "store result" est également utilisée
avec le mode mémoire tampon, vu que la totalité des résultats
est stocké à la fois.
Note:
Lorsque vous utilisez libmysqlclient comme bibliothèque, la limite
mémoire de PHP ne comptera pas la mémoire utilisée pour les
jeux de résultats à moins que les données sont lues dans les
variables PHP. Avec mysqlnd, la mémoire utilisée comprendra
le jeu de résultats complet.
Les requêtes n'utilisant pas la mémoire tampon, les requêtes
MySQL exécutent leur requête et puis attendent
que les données du serveur MySQL soient récupérées. Cela utilise moins de mémoire
côté PHP, mais peut augmenter la charge
sur le serveur. À moins que le jeu de résultats complet ait été
récupéré depuis le serveur, aucune autre requête peut être
envoyée sur la même connexion. Les requêtes n'utilisant pas la
mémoire tampon peuvent également faire référence à un
"use result". Une fois que toutes les lignes de l'ensemble de résultats
ont été récupérées, l'ensemble de résultats disparaît et il n'est plus possible de le parcourir à nouveau.
Suivant ces caractéristiques, Les requêtes non mises en mémoire tampon doivent être utilisées uniquement
lorsqu'on s'attend à obtenir un grand ensemble de résultats qui sera traité séquentiellement.
Les requêtes non mises en mémoire tampon présentent plusieurs pièges qui les rendent plus
difficiles à utiliser, par exemple le nombre de lignes dans l'ensemble de résultats n'est pas connu
avant que la dernière ligne ne soit récupérée.
En raison du fait que les requêtes sont mises en mémoire tampon
par défaut, les exemples ci-dessous vont vous montrer comment
exécuter des requêtes, avec chaque API, sans mise en mémoire
tampon.
Exemple #1 Exemple de requêtes n'utilisant pas la mémoire tampon : mysqli
<?php
$mysqli = new mysqli("localhost", "my_user", "my_password", "world");
$unbufferedResult = $mysqli->query("SELECT Name FROM City", MYSQLI_USE_RESULT);
foreach ($unbufferedResult as $row) {
echo $row['Name'] . PHP_EOL;
}
?>
Exemple #2 Exemple de requêtes n'utilisant pas la mémoire tampon : pdo_mysql
<?php
$pdo = new PDO("mysql:host=localhost;dbname=world", 'my_user', 'my_password');
$pdo->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);
$unbufferedResult = $pdo->query("SELECT Name FROM City");
foreach ($unbufferedResult as $row) {
echo $row['Name'] . PHP_EOL;
}
?>