Mysqli or Die : doit-il toujours conduire à une résiliation ?
Dans MySQLi, la fonction mysqli_query() est souvent accompagnée de or die () pour gérer les erreurs. Cependant, cette approche pose la question : est-il obligatoire de tuer le script en cas d'erreur ?
Alternatives à or die()
PHP propose plusieurs alternatives à la résiliation brutale provoquée par or die(). Une option consiste à configurer MySQLi pour qu'il lève des exceptions sur les erreurs. En utilisant la fonction mysqli_report et en définissant l'indicateur sur MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT, toute erreur MySQLi déclenchera une exception.
Cette approche permet une gestion plus gracieuse des erreurs, comme la journalisation de l'erreur dans une table spécifique. Le code suivant montre comment enregistrer les erreurs à l'aide d'une fonction personnalisée :
function log_mysqli_error($query, $error) { // Write the error to a log file or table } try { $update_result = mysqli_query($link, $sql_update_login); } catch (mysqli_sql_exception $e) { log_mysqli_error($e->getQuery(), $e->getMessage()); }
Avantages de la gestion des exceptions
L'utilisation des exceptions offre plusieurs avantages :
Conclusion
Bien que mysqli ou die était autrefois une pratique courante, elle est devenue obsolète en raison de ses limites et de ses conséquences négatives. En tirant parti de la gestion des exceptions et de la journalisation personnalisée des erreurs, les développeurs peuvent gérer les erreurs MySQLi plus efficacement, garantissant ainsi la stabilité et la fiabilité de leurs applications.
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!