IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

accès concurrents à une méthode static


Sujet :

C#

  1. #1
    Membre éclairé Avatar de chamamo
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    588
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 588
    Points : 735
    Points
    735
    Par défaut accès concurrents à une méthode static
    slt tout le monde.

    pour exécuter une commande SQL j'ai développé la méthode static suivante:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    static public SqlCommand Command
            {
                get
                {
                    if(s_cmd==null)
                    {
                        s_cmd = new SqlCommand();
                        s_cmd.Connection = Connection;
                    }
                    return s_cmd;
                }
            }
    en suite pour executer ma requete je fais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SqlCommand cmd = DB.Command;   //ma méthode static
    cmd.CommandText = "SELECT ............";
    reader = cmd.ExecuteReader();
    et là j'obtiens le message d'erreur suivant :

    There is already an open DataReader associated with this Command which must be closed first.

    ma question est comment limiter l'accès à ma méthode à un seul accès à la fois.

    merci d'avance.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Ce n'est pas une bonne méthode d'avoir un seul objet SqlCommand : par exemple, si pour chaque résultat d'une requête tu fais une autre requête, ça fout la zone... Si tu es susceptible d'utiliser plusieurs requêtes différentes, il vaut mieux utiliser plusieurs objets SqlCommand. D'ailleurs ce n'est pas plus difficile, il suffit de les créer à partir de l'objet SqlConnection.

    En supposant que tu aies une propriété statique Connection dans ta classe DB, ton code devient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SqlCommand cmd = DB.Connection.CreateCommand();
    cmd.CommandText = "SELECT ............";
    reader = cmd.ExecuteReader();
    Et ça résoud le problème, puisque c'est un nouvel objet SqlCommand.

    Par contre, n'oublie pas de fermer le DataReader après avoir lu tous les résultats...

Discussions similaires

  1. Réponses: 2
    Dernier message: 11/02/2012, 09h57
  2. Accès à une méthode static depuis un thread
    Par fantomchris dans le forum MFC
    Réponses: 7
    Dernier message: 08/07/2009, 19h05
  3. Réponses: 1
    Dernier message: 25/06/2008, 15h29
  4. Accès à une méthode static
    Par demcoul dans le forum Langage
    Réponses: 3
    Dernier message: 22/03/2007, 18h55
  5. accés concurrent à une table
    Par shout dans le forum Oracle
    Réponses: 5
    Dernier message: 06/10/2005, 11h54

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo