Maison >base de données >tutoriel mysql >Pourquoi `ExecuteNonQuery()` lance-t-il \'Il y a déjà un DataReader ouvert...\' ?
DataReader ouvert pendant l'exécution de la connexion
Lors de l'utilisation d'un projet Visual Studio 2010/.Net 4.0 et MySQL, un développeur a rencontré l'exception : " Il existe déjà un DataReader ouvert associé à cette connexion qui doit d'abord être fermé."
Le code en question tente de s'exécuter une autre instruction SQL alors qu'un lecteur de données est ouvert. Plus précisément, une exception est levée sur la ligne cmdInserttblProductFrance.ExecuteNonQuery();.
Ce problème survient car la connexion est utilisée à la fois pour le lecteur de données et pour la commande ExecuteNonQuery. Selon MSDN, une telle utilisation n'est pas prise en charge :
"Notez que tant qu'un DataReader est ouvert, la connexion est utilisée exclusivement par ce DataReader. Vous ne pouvez exécuter aucune commande pour la connexion, y compris la création d'un autre DataReader, jusqu'à ce que le Le DataReader d'origine est fermé."
Pour résoudre ce problème, fermez le lecteur de données avant de tenter d'exécuter l'instruction SQL supplémentaire.
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!