Maison >base de données >tutoriel mysql >Pourquoi `ExecuteNonQuery()` lance-t-il \'Il y a déjà un DataReader ouvert...\' ?

Pourquoi `ExecuteNonQuery()` lance-t-il \'Il y a déjà un DataReader ouvert...\' ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-02 06:06:11296parcourir

Why Does `ExecuteNonQuery()` Throw

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn