Dépannage de la récupération de données non numériques dans MySQL à l'aide de PDO
Lors de l'interrogation de bases de données MySQL avec PDO, vous pouvez rencontrer des situations où des valeurs entières sont récupérées sous forme de chaînes au lieu de types numériques. Malgré les tentatives de modification de l'attribut PDO::ATTR_STRINGIFY_FETCHES, une erreur apparaît indiquant qu'il n'est pas supporté par le pilote MySQL. Ce problème survient car le pilote MYSQLND, introduit dans PHP 5.3, gère la conversion des types de données différemment des autres pilotes.
Pour résoudre ce problème, nous devons désactiver la fonctionnalité d'émulation d'instructions préparées de PDO. Cela peut être fait en définissant l'attribut PDO::ATTR_EMULATE_PREPARES sur false lors de la création de l'objet PDO :
new PDO($dsn, $user, $pass, array( PDO::ATTR_EMULATE_PREPARES => false ))
Lorsque des instructions préparées sont utilisées, MYSQLND convertira les valeurs numériques de la base de données en leurs types PHP natifs, vous permettant de travaillez directement avec des entiers au lieu de chaînes. Il est important de noter que PDO::ATTR_STRINGIFY_FETCHES n'est pas applicable au pilote MySQL. En désactivant l'émulation, nous garantissons que les types de données numériques sont traités correctement, éliminant ainsi le besoin de conversions de chaînes supplémentaires.
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!