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
Libérer: 2024-12-02 06:06:11
original
301 Les gens l'ont consulté

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal